虚拟DOM树

虚拟DOM树:

**什么是: 仅包含可能变化的节点和可能变化的属性的树结构

alt title id ….

{{uname}}

id class title name

{{score}}

{ el:”#app”, children:[ {el:”h1”, innerText:uname}, {el:”h2”,innerText:score} ] } 为什么: 内容少,便于快速遍历比较不同 如何发挥作用: 当data中模型变量改变时,会通知虚拟DOM树 虚拟DOM树先缓存本次的修改在元素对象上 将一批修改生成新的DOM子树和原虚拟DOM树做对比。 一旦发现不同的元素或内容,就只更新有修改的元素 虚拟DOM树中,封装了传统DOM API: createElement() appendChild() .innerHTML,避免了程序员编写大量重复的代码。 懒加载 Vue首屏加载非常慢 原因: 当打包应用时,将所有JavaScript代码打包在一个文件中,导致js代码非常庞大,严重影响页面加载速度。 解决: 1. 配置打包工具,将组件分别打包到不同的js代码块中 build/webpack.base.conf.js output:{ path: config.build.assetsRoot, filename:’[name].js’, //新增 chunkFilename:”[name].js”, publicPath: process.env.NODE_ENV===”production” ?config.build.assetsPublicPath :config.dev.assetsPublicPath } 2. 当路由请求到该组件时,才动态加载组件的内容 路由字典中,路由配置和以前完全一样 但是在引入组件对象时: import Index from ‘@/views/Index.vue’ 改为 const Index=()=>import(‘@/views/Index.vue’)//仅定义函数 //暂未执行 //暂时不引入Index.vue 当用户在vue中请求当前组件对应的路由地址时,由vue-router自动调用加载函数,动态请求Index.vue组件对象**
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
虚拟DOM(Virtual DOM)是一种在内存中用 JavaScript 对象表示网页的 DOM 结构的技术。通过使用虚拟DOM,可以在保持页面功能不变的同时,提高网页性能的主要原因如下: 1. 批量更新:虚拟DOM能够将多个DOM操作批量处理,减少了直接操作实际DOM的次数。通过比较虚拟DOM和实际DOM的差异,只对需要更新的部分进行实际DOM操作,从而减少了浏览器的重绘和回流次数。 2. 减少重绘和回流:虚拟DOM可以通过比较更新前后的虚拟DOM差异,只更新需要变化的部分。这种优化方式可以减少浏览器对页面进行重绘和回流的次数,从而提高网页性能。 3. 提高渲染效率:虚拟DOM可以在内存中进行操作,而不是直接操作实际DOM。在虚拟DOM中进行各种计算和操作要比直接在实际DOM中进行快得多。这样可以提高页面的渲染效率,减少用户在页面上的等待时间。 4. 跨平台支持:虚拟DOM是对实际DOM的抽象表示,在不同平台上运行的应用程序可以共享相同的虚拟DOM操作逻辑。这种跨平台支持使得开发者能够更轻松地开发和维护多平台的应用程序。 需要注意的是,虚拟DOM并不一定总是能够提高网页性能。在某些情况下,虚拟DOM的额外计算和比较操作可能会带来一定的性能开销。因此,在实际应用中,仍然需要根据具体情况综合考虑使用虚拟DOM的优缺点,并进行性能测试和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值