JS中的原型和原型链(面试中奖率120%)

屡战屡败,屡败屡战。
生活总是给我们无穷尽的打击。
磨我们的性子,让我们没有了棱角。

下面给大家分享一道面试中奖率120%的题:JS中的继承(至少我是被坑了6+)
还是老规矩,先上代码

            function Base(name){
                this.sex = 0;
                this.name = name || 'base';
                this.hello = function(){
                    console.log("hello " + name);
                };
            }
            Base.prototype.say = function(){
                console.log('name:'+this.name);
            };
            function Extend(name,num){
                //让Base能初始化属性
                Base.call(this,name);
                this.num = num || 0;
            }
            //注意,这里是new Base()而不是Base.prototype
            //因为new Base()是新建了一个对象,这样可以不会影响到Base.prototype
            //否则如果直接操作Base.prototype,会污染Base.prototype
            Extend.prototype = new Base();
            //前面由于将prototype变为了new Base()所以构造方法默认是Base的
            //这里需要手动替换回来
            Extend.prototype.constructor = Extend;

            var one = new Extend('one',2);
            
            console.log(Extend.__proto__);//function () {}
            console.log(one instanceof Extend);//true
            console.log(one instanceof Base);//true
            console.log(one.constructor === Extend);//true
            console.log(one.__proto__ === Extend.prototype);//true
            
            
            console.log(one.name);//one
            console.log(one.sex);//0
            console.log(one.num);//2
            one.say();//name:one
            one.hello();//hello one

面试只要写着一套绝对没有问题 perfect !
这里再给大家解释几个概念:

constroctor: 指向它的构造函数
__proctor__: 指向产生它的原型
call、apply和bindde 异同:
同:
1、都是用来改变函数的this对象的指向的。
2、第一个参数都是this要指向的对象。
3、都可以利用后续参数传参。
异:
1、call和apply都是对函数的直接调用,而bind方法返回的仍然是一个函数,因此后面还需要()来进行调用才可以。
2、call后面的参数与方法中是一一对应的,而apply的第二个参数是一个数组,数组中的元素是和方法中一一对应的
具体写法:
1、xw.say.call(xh)
2、xw.say.apply(xh)
3、xw.say.bind(xh)()
原型链图.png

完整的一条继承链:
new Extend() -> Extend.prototype -> Base.prototype ->Object.prototype -> null
盘古开天地,本来世界什么都没有,是null,后来衍生出来了Object.prototype,基于Object.prototype又产生了Function.prototype,他们都是函数对象
new object()、new function()都是实例对象
最后再上一个完整原型链图:

完整原型链图.jpg

refer:
1、JavaScript筑基篇(三)->JS原型和原型链的理解
2、javascript中apply、call和bind的区别

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,560评论 4 361
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,104评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,297评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,869评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,275评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,563评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,833评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,543评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,245评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,512评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,011评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,359评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,006评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,062评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,825评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,590评论 2 273
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,501评论 2 268

推荐阅读更多精彩内容

  • 工厂模式类似于现实生活中的工厂可以产生大量相似的商品,去做同样的事情,实现同样的效果;这时候需要使用工厂模式。简单...
    舟渔行舟阅读 7,621评论 2 17
  • 大家好,我是IT修真院深圳分院第01期学员,一枚正直纯洁善良的web程序员。 今天给大家分享一下,修真院官网JS(...
    老菜菜阅读 2,438评论 0 1
  • 学习使用过js的人一开始都会觉得js简单,这是因为js语法简单,学习过编程语言的人,很容易掌握js的基本语法并按要...
    易则知阅读 1,286评论 0 11
  • 官方中文版原文链接 感谢社区中各位的大力支持,译者再次奉上一点点福利:阿里云产品券,享受所有官网优惠,并抽取幸运大...
    HetfieldJoe阅读 2,955评论 4 14
  • 声明:此文为转载文章,为了自己看起来方便特此重新排版,等日后看懂了再自己整理疏解,查看原文请点击这里。 正文: J...
    辞镜朱颜阅读 514评论 0 1