最近的一个小任务,需要写一个jQuery的插件,但是根据jQuery官方的文档http://docs.jquery.com/Plugins/Authoring写得有点头晕,主要是对this对象的理解不够深刻和js基础薄弱引起的。
故又翻开了书本,看了经典了《Javascript高级程序设计》、《JavaScript设计模式》,之前囫囵吞枣看过一遍,印象已经不深了,今天又看了一遍,做一下笔记。
封装简单地说就是让外界只能访问对象的共有变量和函数,隐藏细节和数据。
js中有三种方法创建对象,分别为门户大开型、用命名规范区分私有变量、闭包创建真正的私有变量三种。
1.门户大开型,是实现对象的最基础的方法,所有方法与变量都是共有的外界可以访问。
var Book = function(name){
if(this.check(name)){
console.log("error");
throw new Error("name null");
}
this.name = name;
}
Book.prototype = {
check:function(name){
if(!name){
return true;
}
},
getName:function(){
return this.name;
}
}
var book = new Book("哈哈");
//output:哈哈 哈哈
console.log(book.name,book.getName());
这个例子是门户大开型的典型,外界能直接访问对象的属性和方法。可以注意到属性和变量都有"this"来创建。
2.用命名规范区分私有变量,该方法是门户大开型的优化版本,只不过是在私有变量或方法前面用"_"区分,如果有程序员有意使用_getName()的方法来调用方法,还是无法阻止的,不是真正地将变量隐藏。
3.闭包创建真正的私有变量,该方法利用js中只有函数具有作用域的特性,在构造函数的作用域中定义相关变量,这些变量可以被定义域该作用域中的所有函数访问。
var Book2 = function(name){
if(check(name)){
console.log("error");
throw new Error("name null");
}
name = name;
function check(name){
if(!name){
return true;
}
}
this.getName = function(){
return name;
}
}
Book2.prototype = {
display:function(){
//无法直接访问name
return "display:"+this.getName();
}
}
var book2 = new Book2("哈哈");
//output:undefined "哈哈" "display:哈哈"
console.log(book2.name,book2.getName(),book2.display());
可以看到,这个例子中的结果,直接访问name会返回undefined的结果。可以看到这个例子与门户大开型的区别,门户大开型中的变量使用"this"来创建,而这个例子中使用var来创建,check函数也是如此,使得name与check函数只能在构造函数的作用域中访问,外界无法直接访问。
该方法解决了前两种方法的问题,但是也有一定的弊端。在门户大开型对象创建模式中,所有方法都创建在原型对象中,因此不管生成多少对象实例,这些方法在内存中只存在一份,而采用该方法,每生成一个新的对象都会为每个私有变量和方法创建一个新的副本,故会耗费更多的内存。
相关阅读:
学习javascript闭包
Javascript继承机制的设计原理
分享到:
相关推荐
JavaScript经典封装,国内外 JavaScript 经典封装
对window.open进行封装, 使其更好用, 且更兼容, 很多人说window.open不兼容,其实不是, 因为不能直接执行, 必须通过用户手动触发才行;看代码: 代码如下 var openWindow = function(url, options) { var str = ""; ...
国内外JAVASCRIPT经典封装,可以用也可以学-_-
主要给大家介绍了关于javaScript中封装的各种写法的相关资料,文中通过示例代码介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧。
写或读JS代码的时候总有些地方感觉模模糊糊的,于是花了点时间在网上找并稍微整理了一下
JavaScript 封装库:BETA 4.0 版
javascript中如何实现封装,继承和多态
javascript的经典封装,在网上找了14个单一RAR,怪麻烦的,压缩了一下传了上来.不过内容还是不错的.
全面介绍如何用OO方式封装Javascript,高手必看。
Javascript经典封装代码
原生javascript自己封装的一些常用小方法
asp.net开发常用javascript函数封装(c#) 封装了14个函数,很常用哦 网站开发必不可少
相关文章:https://blog.csdn.net/superwebmaster/article/details/80678590 如有问题,下载文件内含有联系方式,可以一起讨论技术。
因项目需求,自己拼接麻烦,所以将javascript拼接json封装成和java类似的操作,直接put() 与 get() 就可以使用,支持json数组,使用的时候只需要 创建对象 并赋值 然后调用内部参数即可,源码中有示例。因为删除操作...
JavaScript对象封装与单元测试.pdf
javascript的经典封装,还有js实现的10个图片效果,供大家学习!
一个封装好的cookie操作类,完成对Cookie 的增删改查等操作。
纯js正则封装方法,正则截取,正则获取,正则获取所有,正则替换所以
同事用javascript写的计算器,已经封装成对象了(带用例)。 调用起来很方便。