鸿蒙面试题

  • 鸿蒙的状态管理
@state @prop @link
  • @prop和@link的区别
@prop是单向的,只能父组件传子组件
@link是双向的,可以子组件传父组件
  • 跨组件之间通信用什么方式
爷孙组件的参数传递可以使用@provide和@consume进行双向数据传递。
兄弟组件之间数据传递可以使用共同的父组件或者全局状态管理(例如localStorage、AppStorage)
  • @Provider和@Consumer vs @Provide和@Consume的区别?
    | 能力 | V2 装饰器@Provider 和@Consumer V1 装饰器@Provide 和@Consume
    本地初始化 允许本地初始化,当找不到@Provider 的时候使用本地默认值。 禁止本地初始化,当找不到对应的@Provide 时候,会抛出异常。
    支持类型 支持 function。 不支持 function。
    观察能力 仅能观察自身赋值变化,如果要观察嵌套场景,配合@Trace 一起使用。 观察第一层变化,如果要观察嵌套场景,配合@Observed 和@ObjectLink 一起使用。
    alias 和属性名 alias 是唯一匹配的 key,如果缺省 alias,则默认属性名为 alias。 alias 和属性名都为 key,优先匹配 alias,匹配不到可以匹配属性名。
    从父组件初始化 禁止。 允许。
    支持重载 默认开启,即@Provider 可以重名,@Consumer 向上查找最近的@Provider。 默认关闭,即在组件树上不允许有同名@Provide。如果需要重载,则需要配置 allowOverride。
  • foreach和lazyforeach
两者都是对容器组件进行数据加载和渲染。foreach是一次循环加载,lazyforeach是按需加载。
他们的参数有3个,其中两个必选一个可选,必选参数为数据源list,循环的回调;可选参数为函数生成键值
  • HAP、HSP、HAR的区别
HAP是我们自己写的ability包
HSP是动态包,类似windows里的dll文件,可以通过路径引用,不会打包到app包里
HAR是静态包,类似windows里的lib文件,会打包到app包里
  • 多线程了解吗?
鸿蒙有两种多线程方式分别是taskpool和worker,一般情况用taskpool,常驻后台的线程任务用worker。
| 普通任务 | new taskpool.Task() | taskpool.execute() | 立即执行的短时任务,耗时不能超过3分钟。 |
| 延时任务 | new taskpool.Task() | taskpool.executeDelayed() | 为了不影响应用启动的性能,一些不影响启动的初始化类任务往往期望放在延时任务中执行,如拉取线上的配置信息等。 |
| 长时任务 | new taskpool.LongTask() | taskpool.execute() | 希望长时运行的任务一直保持执行,已为其他模块提供特定的服务,比如日志埋点,后台长链接保活等。 |
| 串行任务 | new taskpool.SequenceRunner(),new taskpool.Task() | SequenceRunner. execute() | 用于执行一组需要串行执行的任务 |
| 依赖任务 | task1.addDependency(task2), task1.removeDependency(task2) | taskpool.execute() | 任务之间存在先后依赖关系 |
  • ability的生命周期
onInitialize() - 在Ability创建时调用,用于执行初始化操作。
onStart() - 在Ability启动时调用,用于执行必要的准备工作。
onStop() - 在Ability停止时调用,用于释放资源和清理操作。
onDestroy() - 在Ability销毁时调用,用于进行最终的清理工作。
onActive() - 在Ability从后台返回前台时调用,用于执行恢复操作。
onInactive() - 在Ability从前台进入后台时调用,用于执行保存数据等操作。
  • 组件的生命周期
页面生命周期是指被@Entry装饰的组件的生命周期,主要包含以下几个函数:
onPageShow:页面每次显示时触发,包括路由过程、应用进入前后台等场景。
onPageHide:页面每次隐藏时触发,包括路由过程、应用进入前后台等场景。
onBackPress:当用户点击返回按钮时触发。如果返回值为true,则无法通过返回键返回上一页,用户必须与页面交互才能返回。
自定义组件生命周期是指被@Component装饰的UI单元的生命周期,主要包含以下几个函数:
aboutToAppear:在创建自定义组件的新实例后,执行其build函数之前触发。可以在此函数中改变状态变量,更改将在后续执行build函数中生效。
onDidBuild:组件build()函数执行完成之后回调该接口,不建议在onDidBuild函数中更改状态变量、使用animateTo等功能,这可能会导致不稳定的UI表现。
aboutToDisappear:在自定义组件销毁前触发。不允许在此函数中改变状态变量,特别是对@Link变量的修改可能会导致应用程序行为不稳定。
  • 鸿蒙原生与web的交互方式
import { webview } from '@kit.ArkWeb'

@Entry
@Component
struct WebComponent {
  controller: webview.WebviewController = new webview.WebviewController()
  
  build() {
    Column() {
      // 三种加载网页的方式
      Web({ src: $rawfile("index.html"), controller: this.controller })
      Web({ src: "resource://rawfile/index.html", controller: this.controller })
      Web({ src: 'www.example.com', controller: this.controller })
      .zoomAccess(false)
      .aspectRatio(1)
      .javaScriptAccess(true)
      .onPageEnd(async e => {
         // 调用网页内函数并获取返回值
         const res = await this.controller.runJavaScript('test()')
       })
       // 页面上调用 confirm() 函数时触发,以此来实现页面向原生通信
      .onConfirm(event => {
         
      })
    }
  }
}


// module.json5 访问网络前需要申请网络权限
"module": {
    "requestPermissions": [
         {"name": "ohos.permission.INTERNET"}
     ]
 }
  • Navigation组件和router的选择
在不涉及复杂动效、交互、多级路由等场景时,可以使用router。但考虑到应用当前或以后可能出现的复杂场景,以及整体交互体验的一致性,推荐使用Navigation。Navigation可以完全替换router的能力。
  • @Entry 装饰的页面,A 页面跳到 B 页面后再跳回 A 页面,如何获取 B 页面的返回值
router.back({
  url: 'pages/Home',
  params: {
    info: '来自Home页'
  }
})
// 通过调用 router.getParams() 方法进行获取
 onPageShow() {
    const params = router.getParams() as Record<string, string>
    console.log(params)
  }
  • 数据存储方式
缓存有三种方式,分别是localStorage、AppStorage和PresisentStorage。
localStorage是保存页面的数据,页面销毁数据消失。
AppStorage是app级的数据,App进程退出数据消失。
PresistentStorage是持久的数据,一般搭配AppStorage使用。
还有一种是preference,也可以持久存储数据,因为需要一个context参数,一般用于存储一些UI相关的东西。
另外就是数据库,有[键值数据库](https://developer.huawei.com/consumer/cn/doc/harmonyos-guides-V5/data-persistence-by-kv-store-V5)和[关系数据库](https://developer.huawei.com/consumer/cn/doc/harmonyos-guides-V5/data-persistence-by-rdb-store-V5)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352

推荐阅读更多精彩内容