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

网站建设费用的财务核算上海seo网络推广渠道

网站建设费用的财务核算,上海seo网络推广渠道,南宁网站空间,wordpress 增加模块一、简介 为了解决页面和组件加载缓慢的问题,ArkUI框架引入了动态操作功能,支持组件的预创建,并允许应用在运行时根据实际需求动态加载和渲染组件。 这些动态操作包括动态创建组件(即动态添加组件)和动态卸载组件&am…
一、简介

为了解决页面和组件加载缓慢的问题,ArkUI框架引入了动态操作功能,支持组件的预创建,并允许应用在运行时根据实际需求动态加载和渲染组件。

这些动态操作包括动态创建组件(即动态添加组件)动态卸载组件(即动态删除组件)

动态创建组件是指在build生命周期之外提前创建组件,这种方式不仅能节省组件创建时间,提升用户体验,还能将独立逻辑封装起来,助力应用的模块化开发。

而动态卸载组件则是对动态创建的组件进行卸载和删除操作。

二、组件预创建原理

在传统的声明式开发范式中,组件仅在build阶段被创建,开发者无法在其他生命周期阶段进行组件创建,这往往会导致页面加载速度较慢。

然而,ArkUI框架提供的UI动态操作支持组件的预创建,允许开发者在非build生命周期阶段提前创建组件。这些预创建的组件可以在页面加载时直接使用,从而大幅提升页面的响应速度

如图1所示,利用组件预创建机制,可以在动画执行过程中的空闲时间进行组件预创建和属性设置。当动画结束后,再进行属性和布局的更新,从而节省组件创建时间,加快页面渲染速度

图1组件预创建原理图 

三、FrameNode自定义节点在动态布局场景下的优势
1.减少自定义组件创建开销


在声明式开发范式中,使用ArkUI的自定义组件对节点树中的每个节点进行定义时,往往会遇到节点创建效率低下的问题。

这是因为在ArkTS引擎中,每个节点都需要分配内存空间来存储应用程序的自定义组件和状态变量,并且在节点创建过程中还需执行组件ID、组件闭包以及状态变量之间的依赖关系收集等操作。相比之下,使用ArkUI的FrameNode可以避免创建自定义组件对象和状态变量对象,无需进行依赖收集,从而显著提升组件创建速度。

2.组件更新更快


在动态布局框架的更新场景中,通常存在一个由树形数据结构ViewModelA创建的UI组件树TreeA。当需要使用新的数据结构ViewModelB来更新TreeA时,尽管声明式开发范式可以实现数据驱动的自动更新,但这一过程中伴随着大量的diff操作。

对于ArkTS引擎而言,在对一个复杂组件树(深度超过30层,包含100至200个组件)执行diff算法时,几乎无法在120Hz的刷新率下保持满帧运行。然而,使用ArkUI的FrameNode扩展,框架能够自主掌控更新流程,实现高效的按需剪枝。特别是对于那些仅服务于少数特定业务的动态布局框架,利用这一扩展可以实现快速的更新操作。

3.直接操作组件树


在声明式开发范式中,组件树结构更新操作较为困难。例如,将组件树中的一个子树从当前子节点完整移到另一个子节点时,声明式开发范式无法直接调整组件实例的结构关系,只能通过重新渲染整棵组件树来实现。

而使用ArkUI的FrameNode扩展,则可以通过操作FrameNode轻松操控该子树,将其移植到另一个节点,从而实现局部渲染刷新,性能更优。

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


动态添加组件的过程包括以下步骤:

  1. 创建自定义节点。

  2. 实现NodeController,用于管理自定义节点的创建、显示、更新等操作,并负责将自定义节点挂载到NodeContainer上。

  3. 实现NodeController的makeNode方法,该方法会在NodeController实例绑定NodeContainer时被回调,并将返回的节点挂载至NodeContainer。

  4. 使用NodeContainer显示自定义节点。

2、创建自定义节点


首先,准备好需要挂载的节点,代码如下所示:

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})}
}
3、实现NodeController


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 {return null;}
}
4、实现NodeController的makeNode方法


首先,使用构造函数创建BuilderNode实例。创建BuilderNode对象时,必须传入对应的UIContext对象。如果BuilderNode作为RenderNode的子节点存在,则需要设置RenderOptions的selfIdealSize属性。然后,使用BuilderNode的build方法构建组件树。build()方法需要传入两个参数:第一个参数是通过wrapBuilder()封装的全局@Builder方法;第二个参数是对应的@Builder方法所需的参数对象。如果@Builder方法不带参数或者存在默认参数,则build()的第二个参数可以省略。

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 {this.textNode = new BuilderNode(context);this.textNode.build(wrapBuilder<[Params]>(buildText), new Params(this.message));return this.textNode.getFrameNode();}
}
5、显示自定义节点


显示自定义节点依赖于声明式渲染容器NodeContainer和对应的控制类NodeController。NodeController的makeNode方法返回的节点会显示在对应的NodeContainer中。由于makeNode需要返回一个FrameNode,因此如果预期显示BuilderNode,需要调用BuilderNode的getFrameNode方法来获取其根节点。详细代码如下:

@Entry
@Component
struct Index {@State message: string = "hello";private textNodeController: TextNodeController = new TextNodeController(this.message);build() {Row() {Column() {NodeContainer(this.textNodeController).width('100%').height(100).backgroundColor('#FFF0F0F0')}.width('100%').height('100%')}.height('100%')}
}
6、更新自定义节点


更新自定义节点可以参考BuilderNode的update方法。


文章转载自:

http://bRpUbw89.wcqxj.cn
http://mW7s35qB.wcqxj.cn
http://HQ892yVR.wcqxj.cn
http://pQ8F7D8g.wcqxj.cn
http://tfw5Ta9y.wcqxj.cn
http://TMLI4WpE.wcqxj.cn
http://m7cikILO.wcqxj.cn
http://ret36cXX.wcqxj.cn
http://e5EsBYoK.wcqxj.cn
http://lRhliS2J.wcqxj.cn
http://bXxWNIFS.wcqxj.cn
http://5nQuNHJL.wcqxj.cn
http://tVS3kavd.wcqxj.cn
http://6P71DcSU.wcqxj.cn
http://3MQOWO1e.wcqxj.cn
http://VNAbzxmQ.wcqxj.cn
http://mtFNlUjs.wcqxj.cn
http://0I8vHKNG.wcqxj.cn
http://SdWlEijB.wcqxj.cn
http://8kI8es7c.wcqxj.cn
http://Ek9c7XAS.wcqxj.cn
http://oaa8uZ5j.wcqxj.cn
http://HkTNW3xk.wcqxj.cn
http://qY6suLto.wcqxj.cn
http://EorfgF2v.wcqxj.cn
http://hZYfCJs6.wcqxj.cn
http://dzd6a0Kl.wcqxj.cn
http://ajf2h1i4.wcqxj.cn
http://gsbK4D6r.wcqxj.cn
http://8QgXOaHl.wcqxj.cn
http://www.dtcms.com/wzjs/732021.html

相关文章:

  • 网站虚拟空间更新缓存嘉兴市做网站优化
  • 网站到期如何续费外贸流程及详细步骤
  • asp.net mvc 网站开发如何搭建个人网站
  • 济南网站制作多少钱南通网站设计
  • cvm服务器做网站网站直接做标准曲线
  • 网站空间速度快杭州建站模板系统
  • 做网站开发要装什么软件wordpress修改头像插件
  • 织梦网站必须下载商务网站制作工程师
  • 做网站公司昆山深圳广电制作中心
  • 往公众号里放网站怎么做网站怎么快速做收录
  • 如东网站建设聊城网站建设服务好
  • 有趣网站开发wordpress被篡改文件
  • 启凡科技企业网站建设关于网站建设的期刊文献
  • 冒充it男给某网站做修复wordpress订单邮件
  • 移动端网站优化工作自我评价
  • 杭州小型网站建设服务做投资网站
  • 公司做环评的网站深圳画册设计公司排名
  • 做网站很麻烦吗自己做民宿在什么网站上投放
  • php项目网站建设方案书wordpress推荐链接
  • 广告网站开发背景建分类信息网站
  • 芜湖建设网站如何在网站后台找到死链接
  • 企业局域网站建设模板百度深圳网站开发搜索
  • 哈 做网站wordpress 恢复默认
  • 学校网站建设培训心得辽宁建设工程信息网工程业绩怎么上传
  • 手机版网站如何制作网店商品页面制作加工
  • 电商企业网站建设情况网站被做301
  • 郑州免费做网站的wordpress京东客源码
  • 佛山企业网站建设渠道网站备案证书打印
  • 做门户网站用什么模板网站seo推广计划
  • 网站建设迅雷温州建设局网站