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

本文介绍美团如何使用script标签存放HTML代码以减少DOM节点数,从而提高页面加载速度。通过YUI框架,美团实现了商品详情页的高效渲染。

郑昀 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代码技巧,让商品详情页首屏更快地渲染出来。
 
我的前文:

转载于:https://www.cnblogs.com/zhengyun_ustc/archive/2012/07/22/2603403.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值