编写自己的JS框架

转自:http://blog.163.com/qiliping@yeah/blog/static/111533247201010172145982/

 

随着web2.0技术的流行,JavaScript、Ajax等技术也逐渐普遍,开源界出现了许多优秀的js框架,比如jQuery、prototype等,使用这些js框架只需要写一些简单的代码就能实现我们需要的复杂的功能,当然我们也可以脱离这些js框架,去尝试编写自己的js框架,封装一些自己常用的js功能,方便自己的使用,下面让我们一起来探讨如何编写自己的js框架。     

      构建js框架的注意事项:

      1. 不要使用浏览器检测,要使用能力检测

      由于浏览器的类型和版本太多,以及不断的新的浏览器出现,我们不可能去投入大量的时间和成本去实践检测各种版本的浏览器。“浏览器检测”也叫“版本检测”通常被认为是一种错误的做法,浏览器检测的最佳实践是能力检测,通常也被称为对象检测,指的是在代码执行之前检测某个脚本对象或方法是否存在,而不是依赖于你对某个浏览器具有哪些特定的了解,如果必须的对象或方法存在,则说明该浏览器能使用它,而且代码也能够预期正常执行。能力检测(使用if(xxx.xxxx)的方式)如:

1 if(document.body && document.body.getElementsByTagName)

2 {

3    //使用document.body.getElementsByTagName的代码

4 }

  2. 使用命名空间

 

      当使用多个js库文件时,为了避免在调用时不同js库文件的同名函数的冲突,一般会使用命名空间来解决。JavaScript支持同名函数,但只使用最后一个加载的函数(不支持重载,不会考虑参数,只看函数名字), 哪一个最后被加载,哪一个就会被调用到。所以不使用命名空间的话,就很容易遇到同名函数冲突的问题。

      使用命名空间的两点原则:唯一性,不共享。

      唯一性:挑选一个独一无二的命名空间的名字(如Google Maps的G),注意js是大小写敏感的

      不共享:为了不与著名的一些库(jQuery、prototype)或者其他已有的一些函数冲突,使用匿名函数来实现代码的不共享。如:

1 (function(){

2   //code

3 })()

如何编写自己的js库呢?我们可以按照下面的模板来写:

 1 (function() {

 2 

 3     //注册命名空间gyb到window对象上

 4      window['gyb'] = {}

 5 

 6     //定义一个$函数

 7      function $() {

 8        alert("hello $");

 9     }

10 

11     //把$函数注册到gyb命名空间中

12      window['gyb']['$'] = $;

13 })();

PS:也是刚开始接触,把资料找来,以后好好研究一下!

 ===============================================

下面是收藏的一些很有用的资料,备以后参考使用

===============================================

1.在使用JS框架之前自己写的一些工具代码

http://vb2005xu.iteye.com/blog/235863

2.闭包知识点总结

http://blog.csdn.net/gybyylx/article/details/4739770

3.哪些 JavaScript 框架(库)的源代码最值得阅读和学习?

http://www.zhihu.com/question/19793863

 

 

 

 

你可能感兴趣的:(框架)