好不容易有些空余时间,便拿来写自己的CSS选择器引擎了,这个CSS选择器引擎的目标只有三个:
- 速度要快
- 代码要精简
- 要支持CSS3的选择器。
希望通过这个,能够真正理解那些牛逼的框架中的一部分,比如jQuery,Mootools,YUI等等。花了接近三个星期的时间,大重构了三遍,从最开始的速度极低到现在的极速,每一次都是大换血。在这个过程中,我看到了那些大师写代码的境界,即使我完成了这样一个东西,代码依然很难看。
大家可能看完性能测试才会有兴趣,下图是一个较全的性能测试结果,大家可以在这里测试,大家可以自己跑一跑看(由于加载的东西较多,请耐心等待一会儿再点start按钮)。

代码量目前还没达到我满意的程度,不过已经足够小了,Gzip之后仅仅只有2KB(YUICompressor压缩之后为8.61K(win NTFS)),另外,针对Firefox 3, Opera 9性能还有很大的提升空间,因为我没有使用document.getElementsByClassName。但是这些优化在我看来不再是必要的,因为Firefox的用户应该会很快升级到Firefox 3.5,Opera 10也会很快变成正式版,它们都有本地方法querySelectorAll,所以只要选择器引擎在IE6和IE7下的性能达到最高就可以了,其他的浏览器都有本地方法querySelectorAll了。
在写这个选择器引擎的过程中,更进一步了解了js性能优化的更多方法。
另外,人力有限,此选择器引擎未经过足够完整的案例测试,如果有谁有兴趣帮忙测试者,可以和我联系向我索要源代码,等稳定性达到一定程度后会全面开放源代码。
您可能对这些文章也感兴趣:- 【更新】jQuery 1.3.1的VS智能提示下载
- 让Javascript的智能提示和C#一样强悍
- Mootools 1.2教程(21)——类(二)
- Mootools 1.2教程(7)——设置和获取样式表属性
- Mootools 1.2教程(16)——排序类和方法简介
- jQuery被微软纳入ASP.NET AJAX
- 用JavaScript调用Silverlight(C#)中的方法
- 其实AS和JS互相调用有个很酷的特性
- MooTools的Cookie类太“自作聪明”了
- 关于Math.PI、前自增和后自增
与该文相关的评论:(我也想说几句)还可以进一步压缩到5.12KB.愿楼主分享源代码:admin[question]planeart.cn
国外有个叫mini的选择器,只有1.5kb,后来国内有个人借鉴了把它弄成jquery式的框架——lhgcore.js
infinte@yahoo.cn
谢啦~同时给自己的引擎platina吸收点养分。
Processed in 0.8750168 second(s) , unknow queries
Powered by OWord V0.1, Even Not Alpha
(此博客程序为半成品,请勿索取,以免给您的心灵造成创伤^_^)
鄂ICP备05026031号
2009-8
我来说两句:
用户中心
日志分类

最新日志
统计信息






也给我研究研究mengdasheng@126.com,谢谢。