游戏测试 小论 JS 原型链 (二)

陈子昂 · 2018年04月06日 · 最后由 陈子昂 回复于 2018年04月07日 · 2807 次阅读

继续原型链

这个内容深入了解下去感觉会讲很久。还是快刀斩乱麻吧。小论 JS 原型链 (一)

//由new Function()产生的对象都是函数对象 短回顾
console.log(typeof Object.prototype)//object
console.log(typeof Function.prototype)//function
console.log(typeof Function.prototype.prototype)//undefined

var hero =function () {
    hero.prototype.name ="花千骨";//原型对象name ,原型属性:花千骨
    hero.prototype.sex ="gril";
    hero.prototype.age ="Ghosts kown"
    hero.prototype.Hp =100;
    hero.prototype.say =function () {
        return "子画,我要吃糖醋排骨"
    }
}
var xiaogu =new hero();//小骨是英雄函数的实例化对象
var wonder_woman =new hero();//神奇女侠是英雄函数的实例化对象
wonder_woman.name ="神奇女侠";//修改实例对象内容
xiaogu.__proto__.name ="花万骨";//_proto__等价prototype 修改原型属性
xiaogu.__proto__.age =20

console.log("hero name:%s",xiaogu.name,xiaogu.age,typeof(xiaogu))
console.log("hero name:%s",wonder_woman.name)

var xiaogu =new hero();通过内部的指针proto,指向原型对象 hero.prototype.name,原型对象指向构造器的构造函数的 hero,构造器用来实例化对象的。
wonder_woman 是 hero 的实例化对象,wonder_woman.name ="神奇女侠";,hero.prototype.name ="花千骨",神奇女侠覆盖了花千骨的原型属性。

var pt =hero.prototype.isPrototypeOf(xiaogu,wonder_woman)
console.log(pt) //true 如果挂不存在的会抛错

使用 isPrototypeOf() 方法可以判断检查的多个对象是否挂在 Function.prototype 的原型链上。了解了这个以后,在看看原型链的一个继承关系。

function Hero(){
    this.type = "NordicHero";
}
Hero.prototype.getType = function(){
    return this.type;
}
var hero =new Hero();//hero对象是实例化构造函数Hero
console.log(hero) //Hero { type: 'NordicHero' } 这样更好理解了 返回的是1个object
console.log(hero.type)//NordicHero

function NordicHero(){//北欧神话
    this.name = "yadianna"; //原型对象name属性雅典娜
}
NordicHero.prototype = new Hero();//北欧英雄构造对象是Hero的实例,继承于Hero
console.log(NordicHero.prototype.type)//NordicHero

NordicHero.prototype.getName = function(){
    return this.name;
}
var yadianna =new NordicHero();//
console.log(yadianna.__proto__)//Hero { type: 'NordicHero', getName: [Function] }
console.log(yadianna.__proto__===NordicHero.prototype)//True

实例化对象但是因为 NordicHero 继承于 Hero,js adianna.__proto__结果console.log(yadianna.__proto__)
北欧英雄的实例化对象雅典娜继承于北欧英雄,北欧英雄的原型对象 name 的属性是雅典娜。北欧英雄继承于英雄。好吧,我自己都觉得绕,但实际就是这样的,这块如果了解了,JS 一个很重要的知识点就解决了。

其实如果你能把代码当成一段段结构找到规律和相仿性,实际上不用了解这些也可以写,就好比数学家不学基本语法,都可以写出很深的代码,但不纠结可读性问题。

全剧终...

如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
共收到 3 条回复 时间 点赞
陈子昂 JS 系列学习 基本语法组合 中提及了此贴 04月06日 10:47

没看明白。。。能画一颗继承🌲不?

楼主比较喜欢用实际的代码来演示。 但这其实并不适合作为一篇文章,而更像是楼主个人的笔记。 可能楼主并不擅长讲故事吧。要讲明白原型链以及 proto 和 prototype 的区别其实还是需要很多文字和流程图的。 建议楼主更多的从受众的角度考虑如何做分享~~ 其实楼主在贴代码的同时,着重的讲一讲函数的 prototype 的指向以及对象的 proto 的指向再配合着贴一下类似下面这个图效果会好很多。

孙高飞 回复

😂 不会画图啊。我尽量下次在写细点

需要 登录 后方可回复, 如果你还没有账号请点击这里 注册