博客
关于我
【面向JS--DOM加载过程】
阅读量:477 次
发布时间:2019-03-06

本文共 649 字,大约阅读时间需要 2 分钟。

DOM加载过程中布局优化

DOM(文档对象模型)加载过程的布局优化是前端性能优化中的重要环节. DOM树的修改会导致布局重建,这一过程往往消耗不少资源. 减少布局触发次数是提升应用性能的关键.

传统的DOM操作会导致频繁的布局重建. 首次想到的解决方案是提前在内存中构建一个完整的DOM子树,然后一次性将其挂载到页面 DOM树中. 这种方法可以避免在添加多个平级元素时触发多次布局.

现今的主流前端框架如Vue和React正是基于这种原则开发的. 它们使用虚拟DOM的思想,将所有需要更新的部分先在内存中构建成一个完整的片段(以DocumentFragment为核心), 最后再将整个片段挂载到实例 DOM树中.

文档片段的使用场景主要是有效管理内存中的 DOM子树. 通过在片段内构建完整的 DOM结构,可以避免为每个子元素单独触发布局. 这对于同时添加多个平级元素的场景尤为有效.

如何操作

  • 创建一个文档片段对象: var frag = document.createDocumentFragment();
  • 将需要添加的子元素依次追加到文档片段中: frag.appendChild(elem);
  • 将构建好的文档片段挂载到目标父节点中: parent.appendChild(frag);
  • 通过上述方法,布局触发次数可以从 n 次减少到仅一次,从而大幅度提升性能表现.

    这种优化策略特别适用于需要一次性添加多个平级节点的场景. addTo DOM树时仅触发一次布局,减少了重绘操作对性能的消耗.

    转载地址:http://xmxdz.baihongyu.com/

    你可能感兴趣的文章
    ElasticSearch - 基于 DSL 、JavaRestClient 实现数据聚合
    查看>>
    ElasticSearch - 基于 JavaRestClient 操作索引库和文档
    查看>>
    ElasticSearch - 基于 JavaRestClient 查询文档(match、精确、复合查询,以及排序、分页、高亮)
    查看>>
    ElasticSearch - 基于 “黑马旅游” 案例,实现搜索框、分页、条件过滤、附近酒店、广告置顶功能
    查看>>
    20241012更新_yum install 找不到合适的yum源_yum源不起作用_yum无法安装程序_Linux默认源替换---Linux工作笔记067
    查看>>
    ElasticSearch - 基础概念,以及和 mysql 的对比
    查看>>
    ElasticSearch - 索引库和文档相关命令操作
    查看>>
    elasticsearch 7.7.0 单节点配置x-pack
    查看>>
    ElasticSearch 中 REST API 详解
    查看>>
    Elasticsearch 之(16)_filter执行原理深度剖析(bitset机制与caching机制)
    查看>>
    Elasticsearch 时区问题
    查看>>
    Elasticsearch 索引字段类型为text,添加keyword类型操作
    查看>>
    Elasticsearch(四) es出现的问题:填坑
    查看>>
    elasticsearch-5.1.1 安装的问题
    查看>>
    Elasticsearch7.3.1启动指定JDK11
    查看>>
    Elasticsearch下载安装
    查看>>
    Elasticsearch入门教程(Elasticsearch7,linux)
    查看>>
    elasticsearch的helpers.bulk和es_client.bulk的用法
    查看>>
    ElasticSearch设置字段的keyword属性
    查看>>
    Elasticsearch设置账号密码
    查看>>