HarmonyOS 鸿蒙面试第一弹

鸿蒙面试第一弹

答案持续更新中

  • 1、自我介绍
  • 2、鸿蒙项目介绍
  • 3、你接触鸿蒙多久了
  • 4、项目给你,鸿蒙项目给你能独立完成吗?
  • 5、装饰器有哪些
ts 复制代码
  + @Component:用于定义可重用的UI组件。
  + @Entry:用于标识页面的入口组件。
  + @Reusable:实现组件复用,可以优化加载性能并减少应用卡顿。
  + @Preview:用于预览器预览,与@Entry和@Component配合使用可在预览器上进行视图展示。
  + @Observed(或@Observerd):与@ObjectLink装饰器联动,用于观察深层次的嵌套数据变化。
  + @Require:用于校验构造传参。
  + @BuilderParam 和 @Builder:自定义组件时,可只复用组件的逻辑,外部UI使用@BuilderParam传入。
  + @State:用于标记状态信息,表示该属性会随时间推移而发生变化,并与组件的UI渲染相关联。
  + @Prop:用于在子组件中定义那些需要从父组件接收的属性,建立单向同步关系。
  + @Link:与其父组件中的数据源共享相同的值,实现双向数据同步。
  + @Provide 和 @Consume:用于祖先与后代组件的双向数据同步,实现跨层级传递。
  + @StorageProp 和 @StorageLink:应用级别的UI状态存储装饰器。
  + @LocalStorageLink 和 @LocalStorageProp:页面级的UI状态存储装饰器。
  + @Watch:用于监听状态变量的变化,当状态变量变化时,触发相应的回调函数。
  + @Styles:用于定义并复用自定义样式,将多条样式设置提炼成一个方法。
  + @Extend:在@Styles的基础上,用于扩展原生组件样式。
  + @Concurrent:在使用TaskPool时,执行的并发函数需要使用该装饰器修饰。
  + @Track:class对象的属性装饰器,当一个class对象是状态变量时,@Track装饰的属性发生变化,只会触发该属性关联的UI更新。
  • 6、UIAbility、Page、Component生命周期 onCreate场景
    • UIAbility生命周期
ts 复制代码
+ Create:在应用加载过程中,UIAbility实例创建完成时触发。系统会调用onCreate()回调,在这个阶段,开发者可以进行页面初始化操作,例如变量定义、资源加载等。
+ Foreground:UIAbility实例切换到前台时触发。对应的是onForeground()回调,在UI可见之前触发,开发者可以在这个回调中申请系统需要的资源。
+ Background:UIAbility切换到后台时触发。也就是UIAbility的UI完全不可见之后,可以在onBackground()回调中释放资源或执行一些比较耗时的操作,如状态保存、停止定位功能等,以节省系统资源消耗。
+ Destroy:在UIAbility实例销毁时触发。对应的回调是onDestroy(),开发者可以在这个回调中进行系统资源释放、数据保存等操作。
复制代码
+ Page生命周期(被@Entry装饰的组件)
ts 复制代码
+ onPageShow:页面每次显示时触发一次,包括路由过程、应用进入前台等场景。这是进行页面数据加载、动画启动等操作的理想时机。
+ onPageHide:页面每次隐藏时触发一次,包括路由过程、应用进入后台等场景。此时页面仍然保留在内存中,但不再对用户可见。开发者可以在此函数中暂停一些不必要的后台操作,以节省系统资源。
+ onBackPress:当用户点击返回按钮或执行其他返回操作时触发。开发者可以在此函数中执行一些清理工作,如保存用户输入、确认用户是否真的要离开页面等。
复制代码
+ Component生命周期(被@Component装饰的自定义组件)
ts 复制代码
+ aboutToAppear:组件即将出现时回调该接口。具体时机为在创建自定义组件的新实例后,在执行其build()函数之前执行。允许在aboutToAppear函数中改变状态变量,更改将在后续执行build()函数中生效。
+ onDidBuild:组件build()函数执行完成之后回调该接口。但不建议在onDidBuild函数中更改状态变量、使用animateTo等功能,这可能会导致不稳定的UI表现。
+ aboutToDisappear:在自定义组件析构销毁之前执行。不允许在aboutToDisappear函数中改变状态变量,特别是@Link变量的修改可能会导致应用程序行为不稳定。
相关推荐
zhanshuo8 小时前
构建可扩展的状态系统:基于 ArkTS 的模块化状态管理设计与实现
harmonyos
zhanshuo8 小时前
ArkTS 模块通信全解析:用事件总线实现页面消息联动
harmonyos
codefish79813 小时前
鸿蒙开发学习之路:从入门到实践的全面指南
harmonyos
yrjw19 小时前
一款基于react-native harmonyOS 封装的【文档】文件预览查看开源库(基于Harmony 原生文件预览服务进行封装)
harmonyos
小徐不徐说1 天前
每日一算:华为-批萨分配问题
数据结构·c++·算法·leetcode·华为·动态规划·后端开发
搜狐技术产品小编20232 天前
搜狐新闻直播间适配HarmonyOs实现点赞动画
华为·harmonyos
zhanshuo2 天前
ArkUI 玩转水平滑动视图:超全实战教程与项目应用解析
harmonyos·arkui
zhanshuo2 天前
ArkUI Canvas 实战:快速绘制柱状图图表组件
harmonyos·arkui
zhanshuo2 天前
手把手教你用 ArkUI 写出高性能分页列表:List + onScroll 实战解析
harmonyos
zhanshuo2 天前
深入解析 ArkUI 触摸事件机制:从点击到滑动的开发全流程
harmonyos