鸿蒙OS JS FA概述

2020-09-18 12:02 更新

JS UI 框架支持纯 JavaScript、JavaScript 和 Java 混合语言开发。JS FA 指基于 JavaScript 或 JavaScript 和 Java混合开发的 FA,下面主要介绍:JS FA 在 HarmonyOS 上运行时需要的基类 AceAbility、加载 JS FA 主体的方法、JS FA 开发目录。

AceAbility

AceAbility 类是 JS FA 在 HarmonyOS 上运行环境的基类,继承自 Ability。开发者的应用运行入口类应该从该类派生,代码示例如下:

  1. public class MainAbility extends AceAbility {
  2. @Override
  3. public void onStart(Intent intent) {
  4. super.onStart(intent);
  5. }
  6. @Override
  7. public void onStop() {
  8. super.onStop();
  9. }
  10. }

如何加载 JS FA

JS FA 生命周期事件分为应用生命周期和页面生命周期,应用通过 AceAbility 类中setInstanceName() 接口设置该 Ability 的实例资源,并通过 AceAbility 窗口进行显示以及全局应用生命周期管理。

setInstanceName(String name)的参数“name”指实例名称,实例名称与config.json 文件中 profile.application.js.name 的值对应。若开发者未修改实例名,而使用了缺省值 default,则无需调用此接口。若开发者修改了实例名,则需在应用 Ability 实例的 onStart()中调用此接口,并将参数“name”设置为修改后的实例名称。

说明

多实例应用的 profile.application.js 字段中有多个实例项,使用时请选择相应的实例名称。

setInstanceName() 接口使用方法:在 MainAbility 的 onStart() 中的 super.onStart() 前调用此接口。以 JSComponentName 作为实例名称,代码示例如下:

  1. public class MainAbility extends AceAbility {
  2. @Override
  3. public void onStart(Intent intent) {
  4. setInstanceName("JSComponentName"); // config.json配置文件中ability.js.name的标签值。
  5. super.onStart(intent);
  6. }
  7. }

说明

需在 super.onStart(Intent) 前调用此接口。

JS FA开发目录

新建工程的 JS 目录如下图所示。

img

在工程目录中:common 文件夹主要存放公共资源,如图片、视频等;i18n 下存放多语言的 json 文件;pages 文件夹下存放多个页面,每个页面由 hml、css 和 js 文件组成。

  • main > js > default > i18n > en-US.json:

此文件定义了在英文模式下页面显示的变量内容。同理,zh-CN.json 中定义了中文模式下的页面内容。

  1. {
  2. "strings": {
  3. "hello": "Hello",
  4. "world": "World"
  5. },
  6. "files": {
  7. }
  8. }

  • main > js > default > pages > index > index.hml:

此文件定义了 index 页面的布局、index 页面中用到的组件,以及这些组件的层级关系。例如:index.hml 文件中包含了一个 text 组件,内容为 “Hello World” 文本。

  1. <div class ="container">
  2. <text class ="title">
  3. {{ $t('strings.hello') }} {{title}}
  4. </text>
  5. </div>

  • main > js > default > pages > index > index.css:

此文件定义了 index 页面的样式。例如:index.css 文件定义了“container”和 “title” 的样式。

  1. .container {
  2. flex-direction: column;
  3. justify-content: center;
  4. align-items: center;
  5. }
  6. .title {
  7. font-size: 100px;
  8. }

  • main > js > default > pages > index > index.js:

此文件定义了 index 页面的业务逻辑,比如数据绑定、事件处理等。例如:变量 “title”赋值为字符串 “World” 。

  1. export default {
  2. data: {
  3. title: '',
  4. },
  5. onInit() {
  6. this.title = this.$t('strings.world');
  7. },
  8. }
以上内容是否对您有帮助:
在线笔记
App下载
App下载

扫描二维码

下载编程狮App

公众号
微信公众号

编程狮公众号