账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    关于js对象关联风格
    • 2018-04-25 00:00
    • 10
    31
    0

    无语,一开始以为各位大神都知道这种风格就没加上代码,结果问题被踩,贵社区戾气真重,佩服佩服。

    在看《你不知道的js》的时候了解了这种代码风格,但是貌似(?)这种代码风格不是特别常见,是因为这种风格有什么弊端吗

    以下是对象关联风格&面向对象风格的对比

    //典型的(‘原型’)面向对象风格
    function Foo() {
       this.me = who;
    }
    Foo.prototype.identify = function() {
         return 'I am '+ this.me;
    }
    function Bar(who) {
        Foo.call(this, who);
    }
    Bar.prototype = Object.create(Foo.prototype);
    Bar.prototype.speak = function() {
        alert('hello, '+ this.identify() + '.');
    };
    var b1 = new Bar('b1');
    var b2 = new Bar('b2');
    
    b1.speak();
    b2.speak();
    //子类Bar继承了父类Foo,然后生成b1和b2的两个实例。b1委托了Bar.prototype。后者委托了Foo.prototype。这种风格很常见。
    //对象关联风格来编写功能完全相同的代码
    Foo = {
         init: function(who) {
              this.me = who;
          },
          identify: function() {
                return 'i am '+ this.me
          }
    };
    Bar = Object.create(Foo);
    Bar.speak = function() {
         alert('hello, '+ this.identify() + '.');
    }
    var b1 = Object.create(Bar);
    b1.init('b1')l
    var b2 = Object.create(Bar);
    b2.init('b2');
    b1.speak();
    b2.speak();
    //在这段代码中同样利用了[[prototype]]把b1委托给Bar并把Bar委托给Foo,和上一段代码一模一样。我们仍然实现了三个对象之间的关联。在这段代码中,我们只是把对象关联起来了,并不需要那些复杂又令人困惑的模仿类的行为(构造函数,原型以及new)。
    0
    打赏
    收藏
    点击回答
    您的回答被采纳后将获得:提问者悬赏的 10 元积分
        全部回答
    • 0
    更多回答
    扫一扫访问手机版

    回答动态

    师傅被妖怪抓走了:发布了悬赏问题火爆全网的“元宇宙”到底是什么?预计能赚取 1积分收益
    酒后略带风情:发布了悬赏问题Android内存中Graphics与Code占用过高预计能赚取 10积分收益
    扛起拖把扫天下:发布了悬赏问题typescript如何导出接口配置?求解,谢谢!预计能赚取 10积分收益
    发布了悬赏问题Vue 如何改变返回页面的路径?如让B页面只能返回到A页面.预计能赚取 11积分收益
    发布了悬赏问题vue H5移动端;底部bottom固定定位,安卓弹起键盘导致页面变形如何解决?预计能赚取 10积分收益
    发布了悬赏问题请问为什么tomcat8.5 GET请求中文正常,POST请求还需要设置UTF-8.预计能赚取 10积分收益
    发布了悬赏问题vue2.5+ts创建以及引入jq的方法预计能赚取 11积分收益
    情场浪女:发布了悬赏问题import ggplot时报错module 'pandas' has no attribute 'tslib'预计能赚取 10积分收益
    见心书画许老师18753375161:发布了悬赏问题echarts3 legend禁止点击事件,允许悬浮事件预计能赚取 11积分收益
    aa_92cb0bd09f:发布了悬赏问题codewar上的一个问题预计能赚取 11积分收益