harmony 鸿蒙系统应用常见问题

  • 2022-08-09
  • 浏览 (1915)

系统应用常见问题

现象描述

LiteOS-A内核(Hi3516、Hi3518平台)直接调用KV存储提供的接口,各参数正常的情况下,编译可执行程序运行失败。

可能原因

直接运行编译出的可执行文件,没有将程序基于AbilityKit转换成应用,不能由BMS在应用安装时正确设置应用数据存储路径,导致KV存储运行失败。

解决办法

显示调用KV存储的UtilsSetEnv接口,设置数据存储路径。

UtilsSetEnv("/storage/com.example.kv");

当前框架中不存在所有Page都可以访问的全局变量。

通过ref属性获取dom中的元素,详细示例如下图所示;获取的元素只能使用它的方法,不能改变属性。

<!--index.hml-->
<div class="container">
   <!--指定组件的ref属性为animator-->
   <image-animator class="image-player" ref="animator" images="{{images}}" duration="1s" onclick="handleClick"></image-animator>
</div>

/* index.js */
export default {
    data: {
        images:[
            {src:"common/frame1.png"},
            {src:"common/frame2.png"},
            {src:"common/frame3.png"}
        ]
    },
    handleClick(){
        //通过$refs属性获取对应的组件,在hml中,组件的ref属性要设置为animator
        const animator = this.$refs.animator;
        const state = animator.getState();
        if(state == "paused"){
            animator.resume();
        }else if(state == "stopped"){
            animator.start();
        }else{
            animator.pause();
        }
    }
}

通过router.replace方法中的params参数来传递,参考代码如下:

第一个页面传递数据:

router.replace({
    uri:'pages/detail/detail',  //要跳转的页面uri
    params:{transferData:this.data}  //传递的数据,数据个数和名称开发者自己定义,
});

第二个界面接受数据:

onInit(){
    const data = this.transferData;  //在onInit函数中接受传递的数据
}  

通过list的scrollTo方法滚动到指定的item,参数是目标item的index。Index参数可以通过scrollend事件获取或者开发者指定。

text支持多行。通过回车键换行或者是不设置text的高度属性,由控件自动根据内容换行。

现象描述

开发者在hml文件中添加的控件无法显示

可能原因

  • 未设置width和height值;

  • 样式设置错误。

处理步骤

(1)检查是否设置width和height值,组件必须显式设置width和height值;

(2)检查组件的样式设置是否正确。

实现页面滑动目前有三种方式:scroll(根组件大小超过屏幕的大小即自动实现scroll效果)、list、swiper。开发者可以参考开发文档查看三者的区别,并加以使用。

除根节点外,Left、Top配合Stack组件使用才有效果。

在进行绑定时,必须先将要绑定的对象或者对象的属性进行定义,不能先绑定后定义

使用div、stack(top left属性)来实现相对和绝对定位。

通过display、show和if来控制控件的显示与隐藏。区别在于:if为false时,组件会从VDOM中移除,而show仅是渲染时不可见,组件依然存在于VDOM中。

Stack组件不支持其子组件设置margin属性。

在应用运行期间只存在一个page,所以router.replace跳转是先销毁前一个页面,然后在新创建一个界面。因此,如果涉及到事件订阅的页面,每次页面创建时要进行事件订阅,跳转离开界面前取消事件订阅。

过多的动态绑定会消耗较多的内存,若非业务需要,尽量不要使用太多的动态绑定。

去掉第一个组件或者去掉最后一个组件,剩余的长度大于swiper长度,loop生效。

数组元素不宜过多,尽量避免对大数组进行频繁操作。

  • 现象描述

执行 “hdc_std list targets”命令后结果为:[Empty]

  • 解决方法

    1. 设备没有被识别: 在设备管理器中查看是否有hdc设备,在通用串行总线设备中会有“HDC Device”信息。如果没有,hdc无法连接。此时需要断开并重联PC和OpenHarmony设备之间的USB连接,或者烧写最新的镜像。
    2. hdc_std工作异常: 可以执行”hdc kill”或者”hdc start -r”杀掉hdc服务或者重启hdc服务,然后再执行hdc list targets查看是否已经可以获取设备信息。
    3. hdc_std与设备不匹配: 如果设备烧写的是最新镜像,hdc_std也需要使用最新版本。
  • 现象描述

点击hdc_std.exe文件无法运行。

  • 解决方法

hdc_std.exe不需要安装,直接放到磁盘上就能使用,也可以添加到环境变量中。通过打开cmd执行hdc_std命令直接使用。

harmony 鸿蒙faqs

harmony 鸿蒙编译构建常见问题

harmony 鸿蒙烧录常见问题

harmony 鸿蒙环境搭建常见问题

harmony 鸿蒙内核常见问题

harmony 鸿蒙常见问题概述

harmony 鸿蒙移植常见问题

harmony 鸿蒙startup常见问题

1  赞