start-with-ets-stage.md 9.6 KB
Newer Older
1
# 使用ArkTS语言开发(Stage模型)
Z
zengyawen 已提交
2

G
ge-yafang 已提交
3 4

> **说明:**
G
ge-yafang 已提交
5
> 
G
ge-yafang 已提交
6
> 请使用**DevEco Studio V3.0.0.900 Beta3**及更高版本。
Z
zengyawen 已提交
7
> 
G
ge-yafang 已提交
8
> 为确保运行效果,本文以使用**DevEco Studio V3.1.0.100**版本为例,点击[此处](https://developer.harmonyos.com/cn/develop/deveco-studio)获取下载链接。
Z
zengyawen 已提交
9 10


G
ge-yafang 已提交
11
## 创建ArkTS工程
Z
zengyawen 已提交
12

G
ge-yafang 已提交
13
1. 若首次打开**DevEco Studio**,请点击**Create Project**创建工程。如果已经打开了一个工程,请在菜单栏选择**File** > **New** > **Create Project**来创建一个新工程。选择**OpenHarmony**模板库,选择模板“**Empty Ability**”,点击**Next**进行下一步配置。
14

G
ge-yafang 已提交
15
   ![01](figures/01.png)
16

G
ge-yafang 已提交
17
2. 进入配置工程界面,**Compile SDK**选择“**9**”,**Model** 选择“**Stage**”,其他参数保持默认设置即可。
18

G
ge-yafang 已提交
19
   ![07](figures/07.png)
Z
zengyawen 已提交
20

G
ge-yafang 已提交
21 22
   > **说明:**
   >
23
   > 支持使用ArkTS[低代码开发](https://developer.harmonyos.com/cn/docs/documentation/doc-guides/ohos-low-code-development-0000001218440652)方式。
G
ge-yafang 已提交
24 25 26 27 28 29
   >
   > 低代码开发方式具有丰富的UI界面编辑功能,通过可视化界面开发方式快速构建布局,可有效降低开发者的上手成本并提升开发者构建UI界面的效率。
   >
   > 如需使用低代码开发方式,请打开上图中的Enable Super Visual开关。
   
3. 点击**Finish**,工具会自动生成示例代码和相关资源,等待工程创建完成。
30

Z
zengyawen 已提交
31

G
ge-yafang 已提交
32
## ArkTS工程目录结构(Stage模型)
Z
zengyawen 已提交
33

G
ge-yafang 已提交
34
![zh-cn_image_0000001364054489](figures/zh-cn_image_0000001364054489.png)
Z
zengyawen 已提交
35

G
ge-yafang 已提交
36 37
- **entry**:OpenHarmony工程模块,编译构建生成一个[HAP](../../glossary.md#hap)包。
  - **src > main > ets**:用于存放ets源码。
G
ge-yafang 已提交
38 39
  - **src > main > ets > entryability**:应用/服务的入口。
  - **src > main > ets > pages**:应用/服务包含的页面。
40
  - **src > main > resources**:用于存放应用/服务所用到的资源文件,如图形、多媒体、字符串、布局文件等。关于资源文件,详见[资源文件的分类](resource-categories-and-access.md#资源分类)
zyjhandsome's avatar
zyjhandsome 已提交
41
  - **src > main > module.json5**:模块配置文件。主要包含HAP的配置信息、应用/服务在具体设备上的配置信息以及应用/服务的全局配置信息。具体的配置文件说明,详见[module.json5配置文件](module-configuration-file.md)
G
ge-yafang 已提交
42
  - **build-profile.json5**:当前的模块信息 、编译信息配置项,包括buildOption、targets配置等。
G
ge-yafang 已提交
43
  - **hvigorfile.ts**:模块级编译构建任务脚本,开发者可以自定义相关任务和代码实现。
Z
zengyawen 已提交
44

G
ge-yafang 已提交
45
- **build-profile.json5**:应用级配置信息,包括签名、产品配置等。
Z
zengyawen 已提交
46

G
ge-yafang 已提交
47
- **hvigorfile.ts**:应用级编译构建任务脚本。
Z
zengyawen 已提交
48 49 50 51


## 构建第一个页面

52
1. 使用文本组件。
53

G
ge-yafang 已提交
54
   工程同步完成后,在“**Project**”窗口,点击“**entry > src > main > ets > pages**”,打开“**Index.ets**”文件,可以看到页面由Text组件组成。“**Index.ets**”文件的示例如下:
Z
zengyawen 已提交
55
   
56
   ```ts
G
ge-yafang 已提交
57
   // Index.ets
Z
zengyawen 已提交
58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
   @Entry
   @Component
   struct Index {
     @State message: string = 'Hello World'
   
     build() {
       Row() {
         Column() {
           Text(this.message)
             .fontSize(50)
             .fontWeight(FontWeight.Bold)
         }
         .width('100%')
       }
       .height('100%')
     }
   }
   ```

77
2. 添加按钮。
78

G
ge-yafang 已提交
79
   在默认页面基础上,我们添加一个Button组件,作为按钮响应用户点击,从而实现跳转到另一个页面。“**Index.ets**”文件的示例如下:
Z
zengyawen 已提交
80
   
81
   ```ts
G
ge-yafang 已提交
82
   // Index.ets
Z
zengyawen 已提交
83 84 85 86 87 88 89 90 91 92 93
   @Entry
   @Component
   struct Index {
     @State message: string = 'Hello World'
   
     build() {
       Row() {
         Column() {
           Text(this.message)
             .fontSize(50)
             .fontWeight(FontWeight.Bold)
G
ge-yafang 已提交
94
           // 添加按钮,以响应用户点击
Z
zengyawen 已提交
95
           Button() {
Z
zengyawen 已提交
96
             Text('Next')
Z
zengyawen 已提交
97 98 99 100
               .fontSize(30)
               .fontWeight(FontWeight.Bold)
           }
           .type(ButtonType.Capsule)
Z
zengyawen 已提交
101
           .margin({
Z
zengyawen 已提交
102
             top: 20
Z
zengyawen 已提交
103 104 105 106 107 108 109 110 111 112 113 114
           })
           .backgroundColor('#0D9FFB')
           .width('40%')
           .height('5%')
         }
         .width('100%')
       }
       .height('100%')
     }
   }
   ```

115
3. 在编辑窗口右上角的侧边工具栏,点击Previewer,打开预览器。第一个页面效果如下图所示:
116

G
ge-yafang 已提交
117
   ![zh-cn_image_0000001311334976](figures/zh-cn_image_0000001311334976.png)
Z
zengyawen 已提交
118 119 120 121


## 构建第二个页面

122
1. 创建第二个页面。
G
ge-yafang 已提交
123

G
ge-yafang 已提交
124
   - 新建第二个页面文件。在“**Project**”窗口,打开“**entry > src > main > ets **”,右键点击“**pages**”文件夹,选择“**New > ArkTS File**”,命名为“**Second**”,点击“**Finish**”。可以看到文件目录结构如下:
G
ge-yafang 已提交
125

G
ge-yafang 已提交
126
      ![09](figures/09.png)
127

G
ge-yafang 已提交
128
      > **说明:**
G
ge-yafang 已提交
129
      >
G
ge-yafang 已提交
130
      > 开发者也可以在右键点击“**pages**”文件夹时,选择“**New > Page**”,则无需手动配置相关页面路由。
G
ge-yafang 已提交
131
   - 配置第二个页面的路由。在“**Project**”窗口,打开“**entry > src > main > resources > base > profile**”,在main_pages.json文件中的“src”下配置第二个页面的路由“pages/Second”。示例如下:
G
ge-yafang 已提交
132 133
     
      ```json
134
      {
G
ge-yafang 已提交
135
        "src": [
G
ge-yafang 已提交
136 137
          "pages/Index",
          "pages/Second"
G
ge-yafang 已提交
138
        ]
139
      }
G
ge-yafang 已提交
140
      ```
Z
zengyawen 已提交
141

142
2. 添加文本及按钮。
143

G
ge-yafang 已提交
144
   参照第一个页面,在第二个页面添加Text组件、Button组件等,并设置其样式。“**Second.ets**”文件的示例如下:
G
ge-yafang 已提交
145
   
146
   ```ts
G
ge-yafang 已提交
147
   // Second.ets
Z
zengyawen 已提交
148 149 150 151
   @Entry
   @Component
   struct Second {
     @State message: string = 'Hi there'
Z
zengyawen 已提交
152 153 154 155 156 157
   
     build() {
       Row() {
         Column() {
           Text(this.message)
             .fontSize(50)
Z
zengyawen 已提交
158
             .fontWeight(FontWeight.Bold)
Z
zengyawen 已提交
159 160 161 162 163 164 165 166 167 168 169 170 171 172
           Button() {
             Text('Back')
               .fontSize(25)
               .fontWeight(FontWeight.Bold)
           }
           .type(ButtonType.Capsule)
           .margin({
             top: 20
           })
           .backgroundColor('#0D9FFB')
           .width('40%')
           .height('5%')
         }
         .width('100%')
Z
zengyawen 已提交
173
       }
Z
zengyawen 已提交
174
       .height('100%')
Z
zengyawen 已提交
175 176 177 178 179 180 181
     }
   }
   ```


## 实现页面间的跳转

182
页面间的导航可以通过[页面路由router](../reference/apis/js-apis-router.md)来实现。页面路由router根据页面url找到目标页面,从而实现跳转。使用页面路由请导入router模块。
Z
zengyawen 已提交
183

184
1. 第一个页面跳转到第二个页面。
185

G
ge-yafang 已提交
186
   在第一个页面中,跳转按钮绑定onClick事件,点击按钮时跳转到第二页。“**Index.ets**”文件的示例如下:
Z
zengyawen 已提交
187
   
188
   ```ts
G
ge-yafang 已提交
189
   // Index.ets
190
   // 导入页面路由模块
191
   import router from '@ohos.router';
Z
zengyawen 已提交
192 193 194 195 196 197 198 199 200 201 202 203
   
   @Entry
   @Component
   struct Index {
     @State message: string = 'Hello World'
   
     build() {
       Row() {
         Column() {
           Text(this.message)
             .fontSize(50)
             .fontWeight(FontWeight.Bold)
G
ge-yafang 已提交
204
           // 添加按钮,以响应用户点击
Z
zengyawen 已提交
205
           Button() {
Z
zengyawen 已提交
206
             Text('Next')
Z
zengyawen 已提交
207 208 209 210
               .fontSize(30)
               .fontWeight(FontWeight.Bold)
           }
           .type(ButtonType.Capsule)
Z
zengyawen 已提交
211
           .margin({
Z
zengyawen 已提交
212
             top: 20
Z
zengyawen 已提交
213 214 215 216
           })
           .backgroundColor('#0D9FFB')
           .width('40%')
           .height('5%')
Z
zengyawen 已提交
217 218
           // 跳转按钮绑定onClick事件,点击时跳转到第二页
           .onClick(() => {
Y
yamila 已提交
219
             router.pushUrl({ url: 'pages/Second' })
Z
zengyawen 已提交
220 221 222 223 224 225 226 227 228
           })
         }
         .width('100%')
       }
       .height('100%')
     }
   }
   ```

229
2. 第二个页面返回到第一个页面。
230

G
ge-yafang 已提交
231
   在第二个页面中,返回按钮绑定onClick事件,点击按钮时返回到第一页。“**Second.ets**”文件的示例如下:
Z
zengyawen 已提交
232
   
233
   ```ts
G
ge-yafang 已提交
234
   // Second.ets
235
   // 导入页面路由模块
236
   import router from '@ohos.router';
Z
zengyawen 已提交
237 238 239 240
   
   @Entry
   @Component
   struct Second {
Z
zengyawen 已提交
241 242 243 244 245 246 247 248 249 250 251 252
     @State message: string = 'Hi there'
   
     build() {
       Row() {
         Column() {
           Text(this.message)
             .fontSize(50)
             .fontWeight(FontWeight.Bold)
           Button() {
             Text('Back')
               .fontSize(25)
               .fontWeight(FontWeight.Bold)
Z
zengyawen 已提交
253
           }
Z
zengyawen 已提交
254 255 256 257 258 259 260 261 262 263 264 265 266
           .type(ButtonType.Capsule)
           .margin({
             top: 20
           })
           .backgroundColor('#0D9FFB')
           .width('40%')
           .height('5%')
           // 返回按钮绑定onClick事件,点击按钮时返回到第一页
           .onClick(() => {
             router.back()
           })
         }
         .width('100%')
Z
zengyawen 已提交
267
       }
Z
zengyawen 已提交
268 269
       .height('100%')
     }
Z
zengyawen 已提交
270 271 272
   }
   ```

G
ge-yafang 已提交
273
3. 打开Index.ets文件,点击预览器中的![zh-cn_image_0000001311015192](figures/zh-cn_image_0000001311015192.png)按钮进行刷新。效果如下图所示:
274

G
ge-yafang 已提交
275
   ![zh-cn_image_0000001364254729](figures/zh-cn_image_0000001364254729.png)
Z
zengyawen 已提交
276 277 278 279 280 281


## 使用真机运行应用

1. 将搭载OpenHarmony标准系统的开发板与电脑连接。

G
ge-yafang 已提交
282
2. 点击**File** > **Project Structure...** > **Project** > **SigningConfigs**界面勾选“**Automatically generate signature**”,等待自动签名完成即可,点击“**OK**”。如下图所示:
283

G
ge-yafang 已提交
284
   ![06](figures/06.png)
285

G
ge-yafang 已提交
286
3. 在编辑窗口右上角的工具栏,点击![zh-cn_image_0000001364054485](figures/zh-cn_image_0000001364054485.png)按钮运行。效果如下图所示:
287

G
ge-yafang 已提交
288
   ![zh-cn_image_0000001364254729](figures/zh-cn_image_0000001364254729.png)
289

290
恭喜您已经使用ArkTS语言开发(Stage模型)完成了第一个OpenHarmony应用,快来[探索更多的OpenHarmony功能](../application-dev-guide.md)吧。