前端优化三续:用script存放html代码来减少DOM节点数

郑昀 201207

前端优化三续:美团的实践——用script存放html代码来减少DOM节点数

=背景=

与前面 textarea 存放 html 代码 一样,你也可以用 script 来存放,目的都是减少 DOM 节点数。
浏览器在拿到 html 代码时,首次 Tokenization — Tree Construction 的速度就会大大加快。
   http://images.cnblogs.com/cnblogs_com/zhengyun_ustc/255879/o_clipboard026.png
 
=美团是怎么实践的=
在美团商品详情页上,HTML 文档底部遍布着这样的代码:
http://images.cnblogs.com/cnblogs_com/zhengyun_ustc/255879/o_clipboard027.png
 
注意这些 script 的 type 是 text/x-template ,
这是YUI类库自己定义的元素type。
你可以注意到,LABjs 也玩过这个小技巧,也是自己定义了一个元素 type“text/cache”, 由于浏览器不认识这种 type,
就会主动忽略这个 HTML元素。
 
什么时候取出这些隐藏HTML代码呢?
那就要用到这些 script 的 id 了。
YUI的教程上是这么获得 HTML 代码:
    template: Y.one('#todo-item-template').getHTML(),
美团的做法是:
http://images.cnblogs.com/cnblogs_com/zhengyun_ustc/255879/o_clipboard028.png
http://images.cnblogs.com/cnblogs_com/zhengyun_ustc/255879/o_clipboard029.png
 
=结论=
美团由于走的是 YUI3.0 体系,所以可以利用 script 存放html代码技巧,让商品详情页首屏更快地渲染出来。
 
我的前文:
posted @   老兵笔记  阅读(5927)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
历史上的今天:
2010-07-22 语义情感趋势分析入门的一份译稿
点击右上角即可分享
微信分享提示