• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# 使用ArkTS语言开发(FA模型)
2
3
4>  **说明:**
5>
6>  请使用**DevEco Studio V3.0.0.601 Beta1**及更高版本。
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** 选择“**8**”(**Compile SDK**选择“**9**”时注意同步选择**Model** 为“**FA**”,此处以选择“**8**”为例),**Language**选择“**ArkTS**”,其他参数保持默认设置即可。
18
19   ![chooseFAModel_ets](figures/chooseFAModel_ets.png)
20
21   > **说明:**
22   >
23   > DevEco Studio V3.0 Beta3及更高版本支持使用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**,工具会自动生成示例代码和相关资源,等待工程创建完成。
304. 工程创建完成后,在**entry > build-profile.json5**文件中,将targets中的runtimeOS改为“OpenHarmony”,然后点击右上角提示框的**Sync Now**以进行OpenHarmony应用开发。
31
32
33## ArkTS工程目录结构(FA模型)
34
35![zh-cn_image_0000001384652328](figures/zh-cn_image_0000001384652328.png)
36
37- **entry**:OpenHarmony工程模块,编译构建生成一个[HAP](../../glossary.md#hap)包。
38  - **src > main > ets**:用于存放ArkTS源码。
39  - **src > main > ets > MainAbility**:应用/服务的入口。
40  - **src > main > ets > MainAbility > pages**:MainAbility包含的页面。
41  - **src > main > ets > MainAbility > pages > index.ets**:pages列表中的第一个页面,即应用的首页入口。
42  - **src > main > ets > MainAbility > app.ets**:承载Ability生命周期。
43  - **src > main > resources**:用于存放应用/服务所用到的资源文件,如图形、多媒体、字符串、布局文件等。关于资源文件,详见[资源文件的分类](resource-categories-and-access.md#资源分类)。
44  - **src > main > config.json**:模块配置文件。主要包含HAP的配置信息、应用/服务在具体设备上的配置信息以及应用/服务的全局配置信息。具体的配置文件说明,详见[应用配置文件(FA模型)](application-configuration-file-overview-fa.md)。
45  - **build-profile.json5**:当前的模块信息 、编译信息配置项,包括buildOption、targets配置等。其中targets中可配置当前运行环境,默认为HarmonyOS。若需开发OpenHarmony应用,则需开发者自行修改为OpenHarmony。
46  - **hvigorfile.ts**:模块级编译构建任务脚本,开发者可以自定义相关任务和代码实现。
47- **build-profile.json5**:应用级配置信息,包括签名、产品配置等。
48- **hvigorfile.ts**:应用级编译构建任务脚本。
49
50
51## 构建第一个页面
52
531. 使用文本组件。
54
55   工程同步完成后,在“**Project**”窗口,点击“**entry > src > main > ets > MainAbility > pages**”,打开“**index.ets**”文件,可以看到页面由Text组件组成。“**index.ets**”文件的示例如下:
56
57   ```ts
58   // index.ets
59   @Entry
60   @Component
61   struct Index {
62     @State message: string = 'Hello World'
63
64     build() {
65       Row() {
66         Column() {
67           Text(this.message)
68             .fontSize(50)
69             .fontWeight(FontWeight.Bold)
70         }
71         .width('100%')
72       }
73       .height('100%')
74     }
75   }
76   ```
77
782. 添加按钮。
79
80   在默认页面基础上,我们添加一个Button组件,作为按钮响应用户点击,从而实现跳转到另一个页面。“**index.ets**”文件的示例如下:
81
82   ```ts
83   // index.ets
84   @Entry
85   @Component
86   struct Index {
87     @State message: string = 'Hello World'
88
89     build() {
90       Row() {
91         Column() {
92           Text(this.message)
93             .fontSize(50)
94             .fontWeight(FontWeight.Bold)
95           // 添加按钮,以响应用户点击
96           Button() {
97             Text('Next')
98               .fontSize(30)
99               .fontWeight(FontWeight.Bold)
100           }
101           .type(ButtonType.Capsule)
102           .margin({
103             top: 20
104           })
105           .backgroundColor('#0D9FFB')
106           .width('40%')
107           .height('5%')
108         }
109         .width('100%')
110       }
111       .height('100%')
112     }
113   }
114   ```
115
1163. 在编辑窗口右上角的侧边工具栏,点击Previewer,打开预览器。第一个页面效果如下图所示:
117
118   ![zh-cn_image_0000001311334976](figures/zh-cn_image_0000001311334976.png)
119
120
121## 构建第二个页面
122
1231. 创建第二个页面。
124
125   - 新建第二个页面文件。在“**Project**”窗口,打开“**entry > src > main > ets > MainAbility**”,右键点击“**pages**”文件夹,选择“**New > ArkTS File**”,命名为“**second**”,点击“**Finish**”。可以看到文件目录结构如下:
126      ![zh-cn_image_0000001311334932](figures/zh-cn_image_0000001311334932.png)
127
128      > **说明:**
129      >
130      > 开发者也可以在右键点击“**pages**”文件夹时,选择“**New > Page**”,则无需手动配置相关页面路由。
131   - 配置第二个页面的路由。在config.json文件中的“module - js - pages”下配置第二个页面的路由“pages/second”。示例如下:
132
133      ```json
134      {
135        "module": {
136          "js": [
137            {
138              "pages": [
139                "pages/index",
140                "pages/second"
141              ]
142              }
143          ]
144        }
145      }
146      ```
147
1482. 添加文本及按钮。
149
150   参照第一个页面,在第二个页面添加Text组件、Button组件等,并设置其样式。“**second.ets**”文件的示例如下:
151
152   ```ts
153   // second.ets
154   @Entry
155   @Component
156   struct Second {
157     @State message: string = 'Hi there'
158
159     build() {
160       Row() {
161         Column() {
162           Text(this.message)
163             .fontSize(50)
164             .fontWeight(FontWeight.Bold)
165           Button() {
166             Text('Back')
167               .fontSize(25)
168               .fontWeight(FontWeight.Bold)
169           }
170           .type(ButtonType.Capsule)
171           .margin({
172             top: 20
173           })
174           .backgroundColor('#0D9FFB')
175           .width('40%')
176           .height('5%')
177         }
178         .width('100%')
179       }
180       .height('100%')
181     }
182   }
183   ```
184
185
186## 实现页面间的跳转
187
188页面间的导航可以通过[页面路由router](../reference/apis/js-apis-router.md)来实现。页面路由router根据页面url找到目标页面,从而实现跳转。使用页面路由请导入router模块。
189
1901. 第一个页面跳转到第二个页面。
191
192   在第一个页面中,跳转按钮绑定onClick事件,点击按钮时跳转到第二页。“**index.ets**”文件的示例如下:
193
194   ```ts
195   // index.ets
196   // 导入页面路由模块
197   import router from '@ohos.router';
198
199   @Entry
200   @Component
201   struct Index {
202     @State message: string = 'Hello World'
203
204     build() {
205       Row() {
206         Column() {
207           Text(this.message)
208             .fontSize(50)
209             .fontWeight(FontWeight.Bold)
210           // 添加按钮,以响应用户点击
211           Button() {
212             Text('Next')
213               .fontSize(30)
214               .fontWeight(FontWeight.Bold)
215           }
216           .type(ButtonType.Capsule)
217           .margin({
218             top: 20
219           })
220           .backgroundColor('#0D9FFB')
221           .width('40%')
222           .height('5%')
223           // 跳转按钮绑定onClick事件,点击时跳转到第二页
224           .onClick(() => {
225             router.push({ url: 'pages/second' })
226             // 若为API 9工程,则可使用以下接口
227             // router.pushUrl({ url: 'pages/second' })
228
229           })
230         }
231         .width('100%')
232       }
233       .height('100%')
234     }
235   }
236   ```
237
2382. 第二个页面返回到第一个页面。
239
240   在第二个页面中,返回按钮绑定onClick事件,点击按钮时返回到第一页。“**second.ets**”文件的示例如下:
241
242   ```ts
243   // second.ets
244   // 导入页面路由模块
245   import router from '@ohos.router';
246
247   @Entry
248   @Component
249   struct Second {
250     @State message: string = 'Hi there'
251
252     build() {
253       Row() {
254         Column() {
255           Text(this.message)
256             .fontSize(50)
257             .fontWeight(FontWeight.Bold)
258           Button() {
259             Text('Back')
260               .fontSize(25)
261               .fontWeight(FontWeight.Bold)
262           }
263           .type(ButtonType.Capsule)
264           .margin({
265             top: 20
266           })
267           .backgroundColor('#0D9FFB')
268           .width('40%')
269           .height('5%')
270           // 返回按钮绑定onClick事件,点击按钮时返回到第一页
271           .onClick(() => {
272             router.back()
273           })
274         }
275         .width('100%')
276       }
277       .height('100%')
278     }
279   }
280   ```
281
2823. 打开index.ets文件,点击预览器中的![zh-cn_image_0000001311015192](figures/zh-cn_image_0000001311015192.png)按钮进行刷新。效果如下图所示:
283
284   ![zh-cn_image_0000001364254729](figures/zh-cn_image_0000001364254729.png)
285
286
287## 使用真机运行应用
288
2891. 将搭载OpenHarmony标准系统的开发板与电脑连接。
290
2912. 点击**File** > **Project Structure...** > **Project** > **SigningConfigs** 界面勾选“**Automatically generate signature**”,等待自动签名完成即可,点击“**OK**”。如下图所示:
292
293   ![signConfig](figures/signConfig.png)
294
2953. 在编辑窗口右上角的工具栏,点击![zh-cn_image_0000001364054485](figures/zh-cn_image_0000001364054485.png)按钮运行。效果如下图所示:
296
297   ![zh-cn_image_0000001364254729](figures/zh-cn_image_0000001364254729.png)
298
299恭喜您已经使用ArkTS语言开发(FA模型)完成了第一个OpenHarmony应用,快来[探索更多的OpenHarmony功能](../application-dev-guide.md)吧。
300