往期知识点整理
介绍
全局状态保留能力弹窗一种很常见的能力,能够保持状态,且支持全局控制显隐状态以及自定义布局。
效果图预览
使用说明
使用案例参考 短视频案例
- 首先程序入口页对全局弹窗初始化,使用GlobalStateDialogManager.getGlobalStateDialogNodeController().setUIContext(this.getUIContext())。
- 在全局入口页设置弹窗位置GlobalStateDialog()。
- 在需要使用弹窗的页面引入GlobalStateDialogManager,使用operateGlobalStateDialog函数对弹窗显隐及内容布局进行配置。
实现思路
- 使用显隐控制来实现弹窗的状态保留能力,使用NodeContainer来动态操作弹窗的布局以及内容。
/**
* 全局状态保留能力弹窗组件
*/
@Component
export struct GlobalStateDialog {
@StorageProp('isShowGlobalStateDialog') isShowGlobalStateDialog: boolean = false;
build() {
Column() {
、、、
// 弹窗的布局与内容,使用NodeContainer提前占位
NodeContainer(GlobalStateDialogManager.getGlobalStateDialogNodeController())
}
.visibility(this.isShowGlobalStateDialog ? Visibility.Visible : Visibility.Hidden)
.backgroundColor($r('app.color.ohos_global_state_dialog_background_color'))
.height($r('app.string.ohos_global_state_dialog_sixty_percent'))
.borderRadius({
topLeft: $r('app.integer.ohos_global_state_dialog_number_10'),
topRight: $r('app.integer.ohos_global_state_dialog_number_10')
})
.width($r('app.string.ohos_global_state_dialog_hundred_percent'))
}
}
/**
* 全局状态保留能力弹窗控制器,对外提供fillGlobalStateDialog函数来操作弹窗的布局与内容
*/
export class GlobalStateDialogNodeController extends NodeController {
private uiContext: UIContext | null = null;
private rootNode: BuilderNode<[ESObject]> | null = null;
private wrapBuilder: WrappedBuilder<[ESObject]> | null = null;
private params: ESObject;
setUIContext(uiContext: UIContext) {
this.uiContext = uiContext;
}
/**
* 填充全局状态保留能力弹窗的布局以及内容
* @param wrapBuilder 布局
* @param params 内容
*/
fillGlobalStateDialog(wrapBuilder: WrappedBuilder<[ESObject]>, params: ESObject) {
this.wrapBuilder = wrapBuilder;
this.params = params;
this.refreshNode();
}
makeNode(uiContext: UIContext): FrameNode | null {
if (this.rootNode != null) {
// 返回FrameNode节点
return this.rootNode.getFrameNode();
}
// 返回null控制动态组件脱离绑定节点
return null;
}
refreshNode() {
if (!this.uiContext) {
return;
}
// 创建节点,需要uiContext
this.rootNode = new BuilderNode(this.uiContext)
// 创建组件
this.rootNode.build(this.wrapBuilder, this.params)
this.rebuild();
}
}
/**
* 全局弹窗配置项
*/
interface GlobalStateDialogConfig {
isShowGlobalStateDialog?: boolean; // 显隐控制:true显示/false隐藏
wrapBuilder?: WrappedBuilder<[ESObject]>; // 布局
params?: ESObject; // 内容
}
/**
* 管理全局弹窗
*/
export class GlobalStateDialogManager {
private static globalStateDialogController: GlobalStateDialogNodeController = new GlobalStateDialogNodeController();
static getGlobalStateDialogNodeController(): GlobalStateDialogNodeController {
return GlobalStateDialogManager.globalStateDialogController;
}
/**
* 控制全局弹窗的显隐及内容布局
* @param globalStateDialogConfig 配置全局弹窗
*/
static operateGlobalStateDialog(globalStateDialogConfig: GlobalStateDialogConfig) {
if (globalStateDialogConfig.isShowGlobalStateDialog !== undefined) {
AppStorage.setOrCreate('isShowGlobalStateDialog', globalStateDialogConfig.isShowGlobalStateDialog);
}
if (globalStateDialogConfig.wrapBuilder) {
GlobalStateDialogManager.globalStateDialogController.fillGlobalStateDialog(globalStateDialogConfig.wrapBuilder, globalStateDialogConfig.params);
}
}
}
- 使用Stack堆叠能力,为全局弹窗占位,且初始化相关数据。
@Entry
@Component
struct EntryView {
、、、
aboutToAppear(): void {
、、、
GlobalStateDialogManager.getGlobalStateDialogNodeController().setUIContext(this.getUIContext());
、、、
}
build() {
Stack() {
、、、
// 全局状态保留能力弹窗
GlobalStateDialog()
}
.alignContent(Alignment.BottomEnd)
.height('100%')
.backgroundColor($r('app.color.main_background_color'))
}
}
高性能知识点
不涉及
工程结构&模块类型
utils // har类型
|---component
| |---GlobalStateDialog.ets // 全局状态保留能力弹窗
模块依赖
不涉及
最后
总是有很多小伙伴反馈说:鸿蒙开发不知道学习哪些技术?不知道需要重点掌握哪些鸿蒙开发知识点? 为了解决大家这些学习烦恼。在这准备了一份很实用的鸿蒙全栈开发学习路线与学习文档给大家用来跟着学习。
针对一些列因素,整理了一套纯血版鸿蒙(HarmonyOS Next)全栈开发技术的学习路线,包含了鸿蒙开发必掌握的核心知识要点,内容有(OpenHarmony多媒体技术、Napi组件、OpenHarmony内核、OpenHarmony驱动开发、系统定制移植……等)技术知识点。
《鸿蒙 (Harmony OS)开发学习手册》(共计892页):https://gitcode.com/HarmonyOS_MN/733GH/overview
如何快速入门?
1.基本概念
2.构建第一个ArkTS应用
3.……
鸿蒙开发面试真题(含参考答案):
《OpenHarmony源码解析》:
- 搭建开发环境
- Windows 开发环境的搭建
- Ubuntu 开发环境搭建
- Linux 与 Windows 之间的文件共享
- ……
- 系统架构分析
- 构建子系统
- 启动流程
- 子系统
- 分布式任务调度子系统
- 分布式通信子系统
- 驱动子系统
- ……