构造函数作用域的安全

在创建javascrip对象的时候,我们用得最多的写法可能就是构造函数+原型 的方式:

function Person(name,age,job){
this.name = name;
this.age = age;
this.job = job;
}
var p = new Person('zhangsan','25','it');
alert(p.name);//zhangsan

上面的执行没问题,但当我把Person当函数使用的时候:

var p1 = Person('lisi','30','it enginner');
alert(window.name);//lisi

这里Person的name属性已经到了window对象下了,也就是意味着Person的this指向的是window对象了,所以这样是很容易导致很多问题的,不过既然有这样问题出现也就有解决的办法:

function Person(name,age,job){
if(this instanceof Person){
this.name = name;
this.age = age;
this.job = job;
}else{
return new Person(name,age,job);
}
}

这样的话就强制的以实例的方式返回,也就不存在前面作用域安全性问题了
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值