当前位置: 首页 > wzjs >正文

西宁网站建设 哪家好百度广告怎么收费

西宁网站建设 哪家好,百度广告怎么收费,菜鸟网站编程,大气环保网站模板组件动态创建的原理 在声明式范式中,所有的组件在build环节被创建出来,并挂在到组件书中。当组件非多多时,一次性全部创建出来将非常耗时,而通过动态创建组件可以在build环节之前对组件进行预创建,在页面实际加载时可…

组件动态创建的原理

在声明式范式中,所有的组件在build环节被创建出来,并挂在到组件书中。当组件非多多时,一次性全部创建出来将非常耗时,而通过动态创建组件可以在build环节之前对组件进行预创建,在页面实际加载时可以很快的拿来直接使用,从而加快页面渲染速度。

结合动画:

  • 没有预创建时:必须等待动画结束后进行组件创建。
  • 有预创建时:可以在动画加载中就开始创建组件,等动画结束后可以很快的显示组件。

动态创建组件的优势

减少自定义组件的创建开销

组件更新更快

灵活性高,可以自由控制组件中节点的更新,实现高效的节点树裁剪。

直接操作组件树

通过makeNode和replaceBuilderNode可以自由控制组件的创建和更新。

组件的动态添加、更新和删除

代码参考,可以直接在v5.0.5上运行。

import { BuilderNode, FrameNode, NodeController } from '@kit.ArkUI';// 动态组件的业务参数
class Params {text: string = 'Hello World';constructor(text: string) {this.text = text;}
}// 构建动态组件
@Builder
function buildText(params: Params) {Column() {Text(params.text).fontSize(50).fontWeight(FontWeight.Bold).margin({ bottom: 36 })}
}// 通过继承NodeController来控制动态组件的生命周期
class TextNodeController extends NodeController {private textNode: BuilderNode<[Params]> | null = null;private message: string = '';constructor(message: string) {super();this.message = message;}// 动态创建组件节点makeNode(context: UIContext): FrameNode | null {if (this.textNode == null) {this.textNode = new BuilderNode(context);this.textNode.build(wrapBuilder<[Params]>(buildText), new Params(this.message));}return this.textNode.getFrameNode();}// 动态替换组件节点replaceBuilderNode(newNode: BuilderNode<Object[]>) {this.textNode = newNode;this.rebuild();}}@Entry
@Component
struct Index {@State message: string = "hello";@State isShow: boolean = true;private textNodeController: TextNodeController = new TextNodeController(this.message);build() {Row() {Column() {if (this.isShow) { // 控制动态删除组件NodeContainer(this.textNodeController) // 动态添加组件.width('100%').height(100).backgroundColor('#FFF0F0F0')}Button('replaceNode').onClick(() => {// 通过按钮事件来动态更新组件// 用新的节点替换之前的节点this.textNodeController.replaceBuilderNode(this.buildNewNode());})}.width('100%').height('100%')}.height('100%')}// 生成新的节点buildNewNode(): BuilderNode<[Params]> {let uiContext: UIContext = this.getUIContext();let message = 'newNode';let textNode = new BuilderNode<[Params]>(uiContext);textNode.build(wrapBuilder<[Params]>(buildText), new Params(message))return textNode;}}

NodeController生命周期

NodeController用于控制和反馈对应的NodeContainer上的节点的行为,需要与NodeContainer一起使用。下面,对其常用生命周期函数进行说明。

  • makeNode必须要重写的方法,用于构建节点树、返回节点挂载在对应NodeContainer中。在对应NodeContainer创建绑定当前NodeController的时候调用、或者通过rebuild方法调用刷新。
  • aboutToResize当controller对应的NodeContainer在Mesure的时候进行回调,入参为节点的布局大小。
  • aboutToAppear当controller对应的NodeContainer在onAppear的时候进行回调。
  • aboutToDisappear当controller对应的NodeContainer在onDisappear的时候进行回调。
export abstract class NodeController {abstract makeNode(uiContext: UIContext): FrameNode | null;aboutToResize?(size: Size): void;aboutToAppear?(): void;aboutToDisappear?(): void;abstract rebuild(): void;onTouchEvent?(event: TouchEvent): void;
}
http://www.dtcms.com/wzjs/70977.html

相关文章:

  • 网站设置二级域名网站推广方案策划书2000
  • 如何在局域网中做网站app推广软文范文
  • php企业网站管理系统百度指数官方
  • 第三方网站网站优化的方法
  • 外包员工seo服务公司招聘
  • wordpress国外主题网站模板百度助手手机下载
  • 中国城乡建设委员会网站seo实战培训学校
  • 如何建手机网站千度seo
  • 做的好的电商网站品牌营销策划十大要点
  • 政府网站建设 民政局龙岗网络公司
  • 上海营销型企业网站怎么做seo
  • 微信小网站怎么做上海好的seo公司
  • 网站聚合搜索怎么做网站综合查询工具
  • 网站建设要准备什么快速排名优化
  • 郑州专业做微信网站如何做营销推广
  • 做网站多少钱一个seo检测
  • 公司如何做网站一般多少钱营销软文模板
  • 省政府网站集约化建设seo试用软件
  • 怎么选择网站建设公司百度集团官网
  • 长沙行业网站建设seo标题关键词优化
  • 姓氏logo免费设计在线生成百度小程序seo
  • 中国风网站欣赏营销方案的几个要素
  • 百度网站排名怎么做保定seo网站推广
  • wordpress的robots文件seo优化排名营销
  • 毕业设计代做网站靠谱吗著名营销策划公司
  • 商业供应商链接seo快速培训
  • 视觉设计网站有哪些站长统计app官方网站
  • 自己创建的网站seo岗位有哪些
  • 博网站建设网络推广网站建设
  • 盐山国外网站建设小璇seo优化网站