您的位置:首页 > Web前端 > JavaScript

作用域安全的构造函数以及js对象的创建步骤

2016-09-12 15:20 295 查看
//分离构造器
通过new操作符构建一个对象,一般经过四个步骤:
A.创建一个对象
B.将构造函数的作用域赋给新对象(所以this就指向了这个新对象)
C.执行构造函数中的代码
D.返回这个新对象
最后一点就说明了,我们只要返回一个新对象即可。其实new操作符主要是把原型链跟实例的this关联起来,这才是最关键的一点,所以我们如果需要原型链就必须要new操作符来处理。否则this就变成window对象了。
我们来剖析一下jquery的这个结构,以下是我我们常见的类的写法:
var $$ = aJQuery = function(selector){
this.selector = selector;
return this;
}

aJQuery.fn = aJQuery.prototype = {
selectorName:function(){
return this.selector;
},
constructor:aJQuery
}

var a = new $$('aaa');
a.selectorName();

改造成不用new的格式,我们可以通过instanceof判断this是否为当前的实例:
var $$ = aJQuery = function(selector){
if(!(this instanceof aJQuery)){
return new aJQuery(selector);
}
this.selector = selector;
return this;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: