1# 使用ArkTS语言开发(Stage模型) 2 3 4> **说明:** 5> 6> 请使用**DevEco Studio V3.0.0.900 Beta3**及更高版本。 7> 8> 为确保运行效果,本文以使用**DevEco Studio 3.1 Beta2**版本为例,点击[此处](https://developer.harmonyos.com/cn/develop/deveco-studio)获取下载链接。 9 10 11## 创建ArkTS工程 12 131. 若首次打开**DevEco Studio**,请点击**Create Project**创建工程。如果已经打开了一个工程,请在菜单栏选择**File** > **New** > **Create Project**来创建一个新工程。选择**Application**应用开发(本文以应用开发为例,**Atomic Service**对应为原子化服务开发),选择模板“**Empty Ability**”,点击**Next**进行下一步配置。 14 15 ![createProject](figures/createProject.png) 16 172. 进入配置工程界面,**Compile SDK**选择“**9**”,**Model** 选择“**Stage**”,其他参数保持默认设置即可。 18 19 ![chooseStageModel](figures/chooseStageModel.png) 20 21 > **说明:** 22 > 23 > 支持使用ArkTS[低代码开发](https://developer.harmonyos.com/cn/docs/documentation/doc-guides-V3/ide-low-code-overview-0000001480179573-V3)方式。 24 > 25 > 低代码开发方式具有丰富的UI界面编辑功能,通过可视化界面开发方式快速构建布局,可有效降低开发者的上手成本并提升开发者构建UI界面的效率。 26 > 27 > 如需使用低代码开发方式,请打开上图中的Enable Super Visual开关。 28 293. 点击**Finish**,工具会自动生成示例代码和相关资源,等待工程创建完成。 30 314. 工程创建完成后,在**entry > build-profile.json5**文件中,将targets中的runtimeOS改为“OpenHarmony”,然后点击右上角提示框的**Sync Now**以进行OpenHarmony应用开发。 32 33 34## ArkTS工程目录结构(Stage模型) 35 36![zh-cn_image_0000001364054489](figures/zh-cn_image_0000001364054489.png) 37 38- **AppScope > app.json5**:应用的全局配置信息。 39- **entry**:OpenHarmony工程模块,编译构建生成一个[HAP](../../glossary.md#hap)包。 40- **oh_modules**:用于存放三方库依赖信息。关于原npm工程适配ohpm操作,请参考[历史工程手动迁移](https://developer.harmonyos.com/cn/docs/documentation/doc-guides-V3/project_overview-0000001053822398-V3#section108143331212)。 41 - **src > main > ets**:用于存放ArkTS源码。 42 - **src > main > ets > entryability**:应用/服务的入口。 43 - **src > main > ets > pages**:应用/服务包含的页面。 44 - **src > main > resources**:用于存放应用/服务所用到的资源文件,如图形、多媒体、字符串、布局文件等。关于资源文件,详见[资源文件的分类](resource-categories-and-access.md#资源分类)。 45 - **src > main > module.json5**:模块配置文件。主要包含HAP的配置信息、应用/服务在具体设备上的配置信息以及应用/服务的全局配置信息。具体的配置文件说明,详见[module.json5配置文件](module-configuration-file.md)。 46 - **build-profile.json5**:当前的模块信息 、编译信息配置项,包括buildOption、targets配置等。其中targets中可配置当前运行环境,默认为HarmonyOS。若需开发OpenHarmony应用,则需开发者自行修改为OpenHarmony。 47- **hvigorfile.ts**:模块级编译构建任务脚本,开发者可以自定义相关任务和代码实现。 48- **build-profile.json5**:应用级配置信息,包括签名、产品配置等。 49- **hvigorfile.ts**:应用级编译构建任务脚本。 50 51 52## 构建第一个页面 53 541. 使用文本组件。 55 56 工程同步完成后,在“**Project**”窗口,点击“**entry > src > main > ets > pages**”,打开“**Index.ets**”文件,可以看到页面由Text组件组成。“**Index.ets**”文件的示例如下: 57 58 ```ts 59 // Index.ets 60 @Entry 61 @Component 62 struct Index { 63 @State message: string = 'Hello World' 64 65 build() { 66 Row() { 67 Column() { 68 Text(this.message) 69 .fontSize(50) 70 .fontWeight(FontWeight.Bold) 71 } 72 .width('100%') 73 } 74 .height('100%') 75 } 76 } 77 ``` 78 792. 添加按钮。 80 81 在默认页面基础上,我们添加一个Button组件,作为按钮响应用户点击,从而实现跳转到另一个页面。“**Index.ets**”文件的示例如下: 82 83 ```ts 84 // Index.ets 85 @Entry 86 @Component 87 struct Index { 88 @State message: string = 'Hello World' 89 90 build() { 91 Row() { 92 Column() { 93 Text(this.message) 94 .fontSize(50) 95 .fontWeight(FontWeight.Bold) 96 // 添加按钮,以响应用户点击 97 Button() { 98 Text('Next') 99 .fontSize(30) 100 .fontWeight(FontWeight.Bold) 101 } 102 .type(ButtonType.Capsule) 103 .margin({ 104 top: 20 105 }) 106 .backgroundColor('#0D9FFB') 107 .width('40%') 108 .height('5%') 109 } 110 .width('100%') 111 } 112 .height('100%') 113 } 114 } 115 ``` 116 1173. 在编辑窗口右上角的侧边工具栏,点击Previewer,打开预览器。第一个页面效果如下图所示: 118 119 ![zh-cn_image_0000001311334976](figures/zh-cn_image_0000001311334976.png) 120 121 122## 构建第二个页面 123 1241. 创建第二个页面。 125 126 - 新建第二个页面文件。在“**Project**”窗口,打开“**entry > src > main > ets**”,右键点击“**pages**”文件夹,选择“**New > ArkTS File**”,命名为“**Second**”,点击“**Finish**”。可以看到文件目录结构如下: 127 128 ![secondPage](figures/secondPage.png) 129 130 > **说明:** 131 > 132 > 开发者也可以在右键点击“**pages**”文件夹时,选择“**New > Page**”,则无需手动配置相关页面路由。 133 - 配置第二个页面的路由。在“**Project**”窗口,打开“**entry > src > main > resources > base > profile**”,在main_pages.json文件中的“src”下配置第二个页面的路由“pages/Second”。示例如下: 134 135 ```json 136 { 137 "src": [ 138 "pages/Index", 139 "pages/Second" 140 ] 141 } 142 ``` 143 1442. 添加文本及按钮。 145 146 参照第一个页面,在第二个页面添加Text组件、Button组件等,并设置其样式。“**Second.ets**”文件的示例如下: 147 148 ```ts 149 // Second.ets 150 @Entry 151 @Component 152 struct Second { 153 @State message: string = 'Hi there' 154 155 build() { 156 Row() { 157 Column() { 158 Text(this.message) 159 .fontSize(50) 160 .fontWeight(FontWeight.Bold) 161 Button() { 162 Text('Back') 163 .fontSize(25) 164 .fontWeight(FontWeight.Bold) 165 } 166 .type(ButtonType.Capsule) 167 .margin({ 168 top: 20 169 }) 170 .backgroundColor('#0D9FFB') 171 .width('40%') 172 .height('5%') 173 } 174 .width('100%') 175 } 176 .height('100%') 177 } 178 } 179 ``` 180 181 182## 实现页面间的跳转 183 184页面间的导航可以通过[页面路由router](../reference/apis/js-apis-router.md)来实现。页面路由router根据页面url找到目标页面,从而实现跳转。使用页面路由请导入router模块。 185 1861. 第一个页面跳转到第二个页面。 187 188 在第一个页面中,跳转按钮绑定onClick事件,点击按钮时跳转到第二页。“**Index.ets**”文件的示例如下: 189 190 ```ts 191 // Index.ets 192 // 导入页面路由模块 193 import router from '@ohos.router'; 194 195 @Entry 196 @Component 197 struct Index { 198 @State message: string = 'Hello World' 199 200 build() { 201 Row() { 202 Column() { 203 Text(this.message) 204 .fontSize(50) 205 .fontWeight(FontWeight.Bold) 206 // 添加按钮,以响应用户点击 207 Button() { 208 Text('Next') 209 .fontSize(30) 210 .fontWeight(FontWeight.Bold) 211 } 212 .type(ButtonType.Capsule) 213 .margin({ 214 top: 20 215 }) 216 .backgroundColor('#0D9FFB') 217 .width('40%') 218 .height('5%') 219 // 跳转按钮绑定onClick事件,点击时跳转到第二页 220 .onClick(() => { 221 router.pushUrl({ url: 'pages/Second' }) 222 }) 223 } 224 .width('100%') 225 } 226 .height('100%') 227 } 228 } 229 ``` 230 2312. 第二个页面返回到第一个页面。 232 233 在第二个页面中,返回按钮绑定onClick事件,点击按钮时返回到第一页。“**Second.ets**”文件的示例如下: 234 235 ```ts 236 // Second.ets 237 // 导入页面路由模块 238 import router from '@ohos.router'; 239 240 @Entry 241 @Component 242 struct Second { 243 @State message: string = 'Hi there' 244 245 build() { 246 Row() { 247 Column() { 248 Text(this.message) 249 .fontSize(50) 250 .fontWeight(FontWeight.Bold) 251 Button() { 252 Text('Back') 253 .fontSize(25) 254 .fontWeight(FontWeight.Bold) 255 } 256 .type(ButtonType.Capsule) 257 .margin({ 258 top: 20 259 }) 260 .backgroundColor('#0D9FFB') 261 .width('40%') 262 .height('5%') 263 // 返回按钮绑定onClick事件,点击按钮时返回到第一页 264 .onClick(() => { 265 router.back() 266 }) 267 } 268 .width('100%') 269 } 270 .height('100%') 271 } 272 } 273 ``` 274 2753. 打开Index.ets文件,点击预览器中的![zh-cn_image_0000001311015192](figures/zh-cn_image_0000001311015192.png)按钮进行刷新。效果如下图所示: 276 277 ![zh-cn_image_0000001364254729](figures/zh-cn_image_0000001364254729.png) 278 279 280## 使用真机运行应用 281 2821. 将搭载OpenHarmony标准系统的开发板与电脑连接。 283 2842. 点击**File** > **Project Structure...** > **Project** > **SigningConfigs**界面勾选“**Automatically generate signature**”,等待自动签名完成即可,点击“**OK**”。如下图所示: 285 286 ![signConfig](figures/signConfig.png) 287 2883. 在编辑窗口右上角的工具栏,点击![zh-cn_image_0000001364054485](figures/zh-cn_image_0000001364054485.png)按钮运行。效果如下图所示: 289 290 ![zh-cn_image_0000001364254729](figures/zh-cn_image_0000001364254729.png) 291 292恭喜您已经使用ArkTS语言开发(Stage模型)完成了第一个OpenHarmony应用,快来[探索更多的OpenHarmony功能](../application-dev-guide.md)吧。 293