• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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