?确定实例与原型的关系
console.log(A ininstanceof B)
//A是B的实例? console.log(A.prototype.isPrototypeOf(B))//A是B的实例 ?在通过原型链实现继承时,给原型添加新方法的动作务必放在替换原型之后,即
function Animal(){} function Dog(){} Dog.prototype = new Animal(); Dog.prototype.fn1 = function(){//这一步务必放在替换对象之后,否则会被覆盖掉 console.log('fn1); } ?在通过原型链实现继承后,创建原型方法时不能使用对象字面量的方式 ... Dog.prototype = new Animal(); Dog.prototype = {//错误!这样做相当于重写整个Dog.prototype fn1: function(){...}, fn2: function()(...) } //以下才是正确姿势 Dog.prototype.fn1 = function(){...}; Dog.prototype.fn2 = function(){...}; ?通过原型链实现继承,当父类原型中存在引用类型值(如数组,json等)时,对子类实例的修改会影响到父类原型的值~
let Person = function(){}; Person.prototype.arr = [
'orange','apple','banana']; let Person2 = function(){}; Person2.prototype = new Person();//Person2 继承 Person let person2 = new Person2(); console.log(person2.arr);//['orange','apple','banana'] person2.arr.push('strawberry'); let person22 = new Person2(); console.log(person22.arr);//['orange','apple','banana','strawberry'] console.log(person2.arr);//['orange','apple','banana','strawberry'] let person = new Person(); console.log(,person.arr);//['orange','apple','banana','strawberry'] //改变子类的引用类型值arr的值,使超类的arr也受到了影响 //创建对象有很多方法,但大多都各有弊端(详见《高程》)。不过有了ES6的class之后,我就抛弃其他方法啦~强烈推荐使用class

 其实都是书上的内容,你问我为啥要自己再写一遍?加深印象呗~

转载于:https://www.cnblogs.com/LLLLily/p/9934523.html

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值