为什么前者会输出Lucas 后者不会?call动作具体干了什么?
http://dmitrysoshnikov.com/ecmascript/javascript-the-core/
function Foo(){
this.bar="Lucas"
}
let obj={};
obj.__proto__=Foo.prototype;
Foo.call(obj)
console.log(obj.bar); // 输出Lucas
// ------------------------------
function Foo(){
this.bar="Lucas"
}
let obj={};
obj.__proto__=Foo.prototype;
console.log(obj.bar); // undefined
- 每个对象都有__proto__,实际是[[prototype]]的写法;
- 构造函数(对象)不仅有__proto__,还有prototype;
- 构造函数的__proto__指向Function.prototype
- 构造函数的prototype指向Foo.prototype; 拿上述举例子
- Foo.prototype里面实际没有bar;
- 当执行Foo.call(obj)的时候,实际就是运行了Foo(),把Foo()中this指向obj;所以实际就是
- obj.bar=“Lucas”;
本站资源均来自互联网,仅供研究学习,禁止违法使用和商用,产生法律纠纷本站概不负责!如果侵犯了您的权益请与我们联系!
转载请注明出处: 免费源码网-免费的源码资源网站 » js | 原型链
发表评论 取消回复