码迷,mamicode.com
首页 > Web开发 > 详细

js 理解new的运行机制

时间:2016-12-13 19:19:32      阅读:205      评论:0      收藏:0      [点我收藏+]

标签:分析   文章   实例化   做了   man   构造   this   继承   ons   

先上段代码:

 1     function People(name) {
 2       this.name = name;
 3     }
 4 
 5     People.prototype.sayName = function () {
 6       console.log(this.name);
 7     }
 8 
 9     var man1 = new People(‘xiaos‘);
10     console.log(man1.name)
11     man1.sayName();

接下来我们分析下上述代码:

1. 1-3行我们创建了一个People的函数,应为将来要用作构造函数来实例化对象,所以首字母大写(这是好的习惯,也是一种默认的都会遵守的规定吧)

2. 5-7在People的原型对象上添加了sayName方法,什么是原型对象呢?会有另外一篇文章来单独介绍,后续补充~~

3. 第9行,使用new运算符实例化了一个man1对象。这是我们这篇要研究的问题,下面会详细阐述~

4. 第10行打印输出man1的name,第11行调用man1的sayName方法

 

那么问题来了,分析4中为什么能取到name属性和sayName方法呢??其实,这关键在于第3步,new的作用。

那么new究竟做了什么呢?大致分三步,我们用代码分析下过程吧:

1 var obj = {}; // 首先创建一个空的对象
2 
3 obj.__proto__ = People.prototype; // 将空对象的__proto__指向构造函数的原型对象,也就是这句导致上面实例化的对象man1拥有了sayName方法,其实这里是继承了原型对象上的sayName方法
4 People.call(obj, ‘xiaos‘); // 调用People的构造方法,也就是这句导致man1拥有了name属性,有关call用法,本篇暂不介绍了,后续补充;这里简单理解就是People中的this变成了obj
5 
6 return obj; // 返回对象,此刻man1来接收,所以就同时拥有了People的构造函数中的属性还有原型上的方法

 

js 理解new的运行机制

标签:分析   文章   实例化   做了   man   构造   this   继承   ons   

原文地址:http://www.cnblogs.com/zhangxiaos/p/6150754.html

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