为什么会有jQuery、Dojo、Ext、Prototype、YUI、Zepto这么多JS包?

目前流行的JS框架很多Dojo 、Scriptaculous 、Prototype 、yui-ext 、Jquery 、Mochikit、mootools 、moo.fx 等。当然还有很多我都不熟悉的框架,就没有列举。

很多人会在坛子里问,到底哪个框架好呢?哪个框架更牛x呢? 哪个框架OO 更舒服呢?

个人觉得,这是一个新手很容易犯的错误逻辑。 世界上任何东西,任何工具,都没有最好的这一个说法,只有适合和不适合。

我们要根据我们项目的真实需要来选择具有相关特性的框架。

一、JQuery
推荐级别:五星级 
使用场景:任意 
下载地址:jQuery 或google搜 jquery下载 
推荐原因:目前来说我使用最多的框架,也是我个人最推荐的一个。具体好在哪呢? 1.小 2.简单. (学习成本低,但成效高,手册有足够清晰的例子让你从0到项目完成) 3.内部结构好,开源,侧重逻辑 4.对DOM选择强大(其实,JS大多时候是在处理DOM)5.UI扩展好 (这里要提到的就是 Jquery tools和 Jquery UI,大家可以去搜搜看这两个Jquery的扩展UI,你会发现ui原来如此简单,也是因为ui的可扩展性,所以他相对于其他框架毫不逊色)。

二、Extjs
下载地址:HTML5 App Development for Desktop and Mobile. JavaScript Frameworks and Dev Tools from Sencha.
使用场景:内部系统、后台系统、管理系统等。 
推荐级别:四星
推荐理由:Extjs有着非常牛逼的UI设计。设计思想:100%面向对象和组件化的思想,推进RIA(Rich Internet Application)的应用。所以当你做像后台管理,企业内部流程,或其他管理系统的时候,这个东西无疑是你的最佳选择。为什么呢? 因为它几行代码就可以生成非常漂亮的全界面UI,功能强大,样式可选。 做过一个CMS的后台和一个企业内部的系统都是用这个做的,节省了很多人力和时间,而且广受好评。但是有缺点:在一个页面加载很多tab的时候,js可能会要同时下载若干个文件。简单说就是js会比较大!稍复杂,为重量级的框架(包含大量UI),体积大。如果导入ext-all.js,压缩后也有近500k。 但对于后台管理和企业内部系统来说,这个会成为瓶颈。

三、YUI
下载地址:YUI Library
推荐级别:4星 
推荐理由:YUI这个框架我只研究过,但没用在项目中独立使用过。大多是进入项目后,前辈们使用了YUI,然后我们在后续开发中延续了之前的角色而已。很久以前版本的QQ硬盘、mop的某些模块使用过的,但现在就是很清楚哪些人还在用了。YUI和Extjs有点相似,UI方面有很多优势。 
使用场景:拆分YUI的各个模块,对不同需求采用yui中的某部分来填充到自己的模块中。或者是类似于网盘应用这种东东。

四、Dojo
下载地址:Unbeatable JavaScript Tools
推荐级别:四星 
推荐理由:Dojo是功能最为强大的javascript框架,刻意提醒一下:功能最强大。所以它几乎包含了所有你可能想要用到的东西。 Dojo更适合企业应用和产品开发的需要,因为离线存储、DataGrid、2D、3D图形、Chart、Comet等组件对于企业应用来说都是很重要的(当然这些组件还要等一段时间才能稳定下来)。例如,BEA基于Mashup技术开发的产品中已经使用了Dojo。优点:背后强大的支持,IBM、Sun、BEA等,这是非常重要的优势;面向对象的设计、统一的命名空间、包管理机制、可扩展性。但是但是,我们是否需要这些功能?做 web2.0产品是有要这么大的东东? 这个按照你自己的需求来。 而且Dojo缺点很明显,太大,功能太多,复杂,学习曲线太陡;文档的极端不全,API很多不稳定,这是很大的问题;侵入性太大,页面中大量使用Dojo属性,例如<button dojoType="dijit.form.Button" id="helloButton">,如果将来dojo升级或者换一个框架时,负担会很大;性能问题,由于dojo加载采用了同步的机制,会暂时锁定浏览器,导致CPU使用率达到100%,另外,很多组件(Widget)的速度很慢。 但是它做企业应用的话,那简直是如鱼得水。这也是IBM等公司招聘的时候,把Dojo和学习Dojo放在第一位的原因。

五、Prototype
最成熟的。但个人认为可以被Jquery取代。两者相似度也比较高。这里就不多说。

六、Mootools
下载地址:MooTools - a compact javascript framework
推荐级别:4星
推荐理由:OO(面向对象)设计思想。模块化强,耦合度比较低。优点:模块化,各模块代码非常独立,最小的核心只有8k,最大的优点是可以选择使用哪些模块,用的时候只要导入模块就行,完整的补刀180k,压缩后补刀70k;语法简洁直观;特效(effects)比jQuery稍强,现在也在开发Mootools UI。缺点:修改了底层的一些类,如Array、String等,这也是设计思想的不同;在DOM和css selector上不如jQuery强大。

总结

轻量级的选择:

主要是mootools和jquery,

由于它们的设计思想的不同,jQuery是追求简洁和高效,Mootools除了追求这些目标以外,其核心在于面向对象,

所以jQuery适合于快速开发,Mootools适合于稍大型和复杂的项目,其中需要面向对象的支持;

另外,在Ajax的支持上,jQuery稍强一些;在Comet的支持上,jQuery有相关的插件,

Mootools目前没有,但是Comet的核心在于服务器的支持,浏览器端的接口很简单,开发相关的插件很简单。

在面向对象的Javascript Library中,mootools逐渐战胜了prototype(体积大,面向对象的设计不合理等),也包括script.acul.ous(基于prototype,实际上就是prototype上的UI库)。

面向RIA的框架

考虑纯JavaScripty库,目前主要是Dojo和ExtJS(还有YUI)。

Dojo更适合企业应用和产品开发的需要,因为离线存储、DataGrid、2D、3D图形、Chart、Comet等组件对于企业应用来说都是很重要的(当然这些组件还要等一段时间才能稳定下来)。例如,BEA基于Mashup技术开发的产品中已经使用了Dojo。

ExtJS:美观和"易用",并且足够强大。在对UI有比较大的需求时,是首选。

参考文献:

  http://blog.csdn.net/eyetee/article/details/7861741

时间: 2024-12-09 03:43:19

为什么会有jQuery、Dojo、Ext、Prototype、YUI、Zepto这么多JS包?的相关文章

分享一款jquery+css3实现的手风琴效果代码【js插件】

代码适用于大部分浏览器 演示Demo地址:请猛戳 效果图片 程序吧下载地址 分享一款jquery+css3实现的手风琴效果代码[js插件],布布扣,bubuko.com

jquery ajax中支持哪些返回类型以及js中判断一个类型常用的方法?

1 jquery ajax中支持哪些返回类型在JQuery中,AJAX有三种实现方式:$.ajax() , $.post , $.get(). 预期服务器返回的数据类型.如果不指定,jQuery 将自动根据 HTTP 包 MIME 信息来智能判断,比如 XML MIME 类型就被识别为 XML.在 1.4 中,JSON 就会生成一个 JavaScript 对象,而 script 则会执行这个脚本.随后服务器端返回的数据会根据这个值解析后,传递给回调 函数.可用值: •"xml": 返回

模仿yui将css和js打包,加速网页速度

如果你有机会用firebug看看自己网站的网络请求,你会发现请求数量之多超乎你的想象.为减少这个数量,有许多技术方案.比如yui的combo,会将所有需要的js混合成一个文件下载,现代web服务器好像也有这种技术,通过分析网页的链接,将一些文件合并.但这是别人实现的,也许不合你的需求.以下代码是本人在诗篇建站平台上的一个servlet,希望能给你写类似的代码起到一些参考作用. 1.约定格式.这是: http://www.m3958.com/in 的网页源代码的片段,你必须在客户端和服务器端约定格

JQuery validate 在IE兼容模式下出现 js错误(成员找不到)的修正:

JQuery validate 在IE兼容模式下 下出现 js错误(成员找不到)的修正: // Add novalidate tag if HTML5. //this.attr( "novalidate", "novalidate" ); if (typeof (Worker) !== "undefined") { this.attr('novalidate', 'novalidate'); } 将第二行注释掉,换成第三行! JQuery val

Ext原码学习之lang-Object.js

// JavaScript Document (function(){ var TemplateClass = function(){}, ExtObject = Ext.Object = { chain:Object.create || function(object) { TemplateClass.prototype = object; var result = new TemplateClass(); TemplateClass.prototype = null; return resu

Ext原码学习之Ext-more.js

// JavaScript Document Ext.apply(Ext,{ userAgent:navigator.userAgent.toLowerCase(), cache:{}, isSeed:1000, windowId:'ext-window', documentId:'ext-document', isReady:false, enableGarbageCollector:true, enableListenerCollection:true, rootHierarchyState

Ext原码学习之lang-Array.js

// JavaScript Document //Array 方法 (function(){ var arrayPrototype = Array.prototype, slice = arrayPrototype.slice, supportsSplice = (function(){ var array = [],lengthBefore,j = 20; if(!array.splice) { return false; } while(j--) { array.push("A")

jQuery 源码分析和使用心得 - core.js

core是jQuery的核心内容, 包含了最基础的方法, 比如我们常用的 $(selector, context), 用于遍历操作的 each, map, eq, first 识别变量类型的 isArray, isNumeric, type 等 . 这些方法为jQuery后续操作提供最基础的支持. 构造函数 jQuery( selector, context ) 说到jQuery, 大家可能最熟悉的就是 $(selector, context) , 我觉得这也是jQuery受到人们欢迎的很大一部

简单模拟jQuery创建对象的方法,以及封装一个js动画框架

今天无事点开了N年未点开的慕课网,看了一个js动画框架的视频,心血来潮用jQuery的方法封装了一下,虽然不如jQuery,但是还是有点点所获. 什么都不说,直接上代码: /** * 这是框架的唯一对象,使用jQuery框架的创建方法 * @class MyAnimation * @constructor */ function MyAnimation(Selector){ //返回MyAnimation原型链中init()方法创建的对象 return new MyAnimation.proto