• 技术文章 >web前端 >js教程

    关于Javascript 对象(object)的prototype_javascript技巧

    2016-05-16 16:49:02原创385
    Javascript中的每个对象(object)都会有 prototype 。试一下:
    复制代码 代码如下:

    var Richard = new Object();
    alert(typeof(Richard.prototype));

    结果令人郁闷,浏览器弹出来的是 undefined……

    到底是怎么回事呢?

    再看一个例子:
    复制代码 代码如下:

    function Richard(){}
    alert(typeof(Richard.prototype));

    上面的例子似乎说明,只有 function 对象才有 prototype, 而一般的 Object 对象是没有 prototype 的,事实怎样呢?

    我们再来执行一句就明白了:
    复制代码 代码如下:

    var Richard = new Object();
    alert(Richard.__proto__);

    是不是明白了?

    其实我们都有一个误区,就是认为形成 Javascript 对象的prototype chain 的 prototype 就是一个名字为 prototype 的属性,而且是可以访问的。其实,Javascript 的 prototype 和 名字为 prototype 的属性在一开始一点儿关系都没有,是两个不同的事物。

    对于一般对象来说,我们只能通过 __proto__ 这样的属性去访问从 Object 对象继承来的 prototype;

    对于函数对象来说,在其建立的时候,已经将 Function对象的 prototype 赋值给了 prototype 属性。
    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:Javascript prototype
    上一篇:Javascript玩转继承(一)_javascript技巧 下一篇:javascript的数组和常用函数详解_基础知识
    PHP编程就业班

    相关文章推荐

    • JavaScript学习理解之JSON(总结分享)• 浅析React18中的SuspenseList,聊聊有什么用• 带你了解React中的Ref,值得了解的知识点分享• 一起聊聊JavaScript函数式编程• 了解Node.js Nest.js的AOP 架构,聊聊其好处

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网