构造函数作用域的保险

构造函数作用域的安全
在创建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);
    }
}

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