首页 > 代码库 > js 理解new的运行机制
js 理解new的运行机制
先上段代码:
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的运行机制
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。