码迷,mamicode.com
首页 > 其他好文 > 详细

this 和 new 构造函数

时间:2016-01-26 18:13:30      阅读:168      评论:0      收藏:0      [点我收藏+]

标签:

function people(name) {     这样定义是在全局命名空间(global namespace)
   name: name,
   sayname: function() {  
       alert(this.name);
   }
}
 
jack = people("jack");          这个时候  this  指的是 jack
var a = jack.sayname();       
a();                                  输出undefined的,因为a 的 this 指向全局变量(global variable),没有 name 
 
修改后
function People(name) {
   this.name: name,
   sayname: function(){
       alert(this.name);
   }
}
var  a  = new People("jack");   每次new 都会产生新的sayname,使用People.prototype.sayname可以实现共享
 
new 的作用是产生一个全新的空对象,然后调用后面的构造函数   new  fn();   然后把this指向新对象,属性也都加上去
 
下面这种形式也是在实例化,因为是匿名构造函数,所以形式不同:
new (function(a) {this.a = a})()

this 和 new 构造函数

标签:

原文地址:http://www.cnblogs.com/chuangweili/p/5161001.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!