KISSY Mobile 最佳实践

去除不必要的模块加载

Seed 种子文件体积(seed-min.js):15k(gzip)。Mobile 中原生支持querySelectorquerySelectorAll,在 Webkit 内核浏览器中只会载入包装器,即在移动终端会自行加载最小子集,比如这段代码:

// 在 Mobile 中运行
KISSY.use('node');

只会载入node-min.js2k(gzip),即可在 Mobile 中拥有DOM操作的全部功能。

最佳实践,在Mobile中要保留有用的模块,尽管KISSY会主动探测设备并选择性加载,但多余的手动引入模块还是会造成不必要的带宽浪费。

开启 Combo

KISSY Loader 可以开启Combo功能,将多JS文件进行合并输出,以减少HTTP请求数,在移动终端中更要如此,开启方法参照Loader

对于本地文件,使用KMC进行静态合并。

KISSY DOM 的 CSS3 选择器加速

Zepto 由于充分利用了浏览器原生querySelectorquerySelectorAll两个函数来查找DOM,因此DOM查找效率很不错,但并非所有的选择器用这两个函数都能达到速度最快。通过测试发现#id#ClassNametags#id .cls级联查找等场景下,querySelector性能并非最优。我们在 DOM 模块中重构了 CSS3 选择器引擎,有选择的调用原生函数,在90%的场景中让DOM查找速度加倍:

最佳实践:在对选择器查找性能要求苛刻的场景中,使用 KISSY DOM 代替 Zepto。

如果你对选择器有更极致的性能邀请,参考这些最佳实践:

简单选择器

你的选择器只是简单选择器,建议你这样写

// 速度很快
S.one( "#container" ).one( "div.robotarm" );

// 速度更快
S.one( "#container div.robotarm" );

第二行代码执行速度更快,因为选择器被解析为两个Token,对于每个Token,KISSY都会调用最快的方法,而对于简单选择器,尽可能用一个方法包括,由KISSY自身按需调用最快的方法去查找每个Token。测试代码

简单选择器只包含ID,ClassName,Tag和他们的组合。

循环的优化

如果循环中有多级选择器,建议这样写:

// 速度一般
for(var i = 0 ; i < length; i++){
    S.one('#a').one('.b');
}

// 速度更快
var el = S.one('#a');
for(var i = 0 ; i < length; i++){
    el.one('.b');
}

尽可能避免 tag.cls ,直接使用.cls

由于.cls查询在高级浏览器中会直接调用getElementsByClassName,此方法性能仅次于getElementById,而tag.cls会调用querySelector,性能更差。

// 不要这样做
S.one( "div.data .gonzalez" );

// 这样性能更优
S.one( ".data td.gonzalez" );

删除累赘选择器

S.one( ".data table.attendees td.gonzalez" );

// 性能更好: 把中间的选择器去掉,保持选择器的直达和简单
S.one( ".data td.gonzalez" );

选择器多,意味着查询次数多,应当尽可能的避免。

避免全局选择器

尽可能的避免使用模糊查询和全遍历,使用更精确的选择器查询:

S.one( ".buttons > *" ); // 非常耗性能
S.one( ".buttons" ).children(); // 性能好一些
S.one( ".category :radio" ); // 避免这样用
S.one( ".category *:radio" ); // 同上,也要避免
S.one( ".category input:radio" ); // 这种写法更好

触屏事件

KISSY Event 包含对触屏事件的封装,这样载入event模块:

// 在触屏设备中运行
KISSY.use('event');

在触屏设备中将会加载event-min.js:214B(gzip)。事件用法和普通的浏览器事件一样:

Event.on('#t', "swipe", function (e) {
    if(e.direction=='left'){
        e.preventDefault();
    }
});

最佳实践,使用 KISSY Event 封装后的触屏事件,触屏行为更统一、精确。事件种类参照Event

组件的触屏兼容

KISSY Gallery 提供大量兼容 Mobile 的组件,尽可能的使用这些跨终端的组件,比如Slide,支持CSS3动画的加速和手势事件触发切换。


其他重要的优化手段

图片体积优化

性能分为两类:

KISSY 只能保证在 JavaScript 层面优化性能,根据34军规的原则,影响载入性能最大的因素在于HTTP请求数和资源体积,一般情况下占用页面体积80%的是图片,因此优化图片的效果比优化 JavaScript 体积要更显著更重要。

根据不同DPI载入不同尺寸图片

/* 高 dpi */
@media only screen and (min-resolution: 300dpi),
    only screen and (-webkit-min-device-pixel-ratio: 1.5) {
        #header { background-image: url(header-300dpi.png); }
}

/* 低 dpi */
@media only screen and (max-resolution: 299dpi),
    only screen and (-webkit-max-device-pixel-ratio: 1.5) {
        #header { background-image: url(header-72dpi.png); }
}

使用带有alpha通道的PNG8图片

带有半透明效果的图片可以以PNG8形式保存,通过工具tinypng来优化。这类图片体积将会减少一倍。

两篇H5开发最佳实践的 PPT

Fork me on GitHub