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

    图解js中的Object.create方法(附代码实例)

    藏色散人藏色散人2022-11-25 21:16:24转载123
    本文给大家介绍有关ECMAScript 5中 新增的Object.create() 方法,对于不了解的同学,欢迎收藏学习哟~

    大前端成长进阶课程:进入学习

    ECMAScript 5 新增了 Object.create() 方法将原型式继承的概念规范化【推荐学习:JavaScript视频教程

    用法

    var obj = Object.create({name: 'johan', age: 23}) // obj 继承了属性name 和 age
    var obj2 = Object.create(null) // obj2 不继承任何属性和方法
    var obj3 = Object.create(Object.prototype) // 与 {} 和 new Object() 一个意思
    var obj4 = Object.create({}, {
        property1: {
            value: true,
            writable: true
        }
    }) // 第二个参数与 Object.defineProperties() 一致
    图解 Object.create 实现
    function create(proto) {
        function F(){}
        F.prototype = proto
        return new F()
    }

    第一步: function F(){}

    即创建一个函数,因为约定首字母大写,视为构造函数,创建函数 F 时,F 构造函数与和它的原型对象就有了这一层的关系:

    F.prototype === F.prototype; // 假设你把F.prototype当作一个值
    F.prototype.constructor === F;

    1c137449b5dad8aa827e0d3d562ba16.jpg

    第二步:F.prototype = proto

    即将 F.prototype 赋值为传入的 proto,如此就打破了F.prototype = F.prototype 以及 F.prototype.constructor = F ,它们的关系为

    cf1d8013b4b1389a14f99223d0649c0.jpg

    第三步:return new F()

    第三步的解读有点费解,因为这里涉及到 new 的操作,在 new 改变了对象 中我们说过,new 会创建一个对象,并将这个对象的隐式原型(__proto__) 指向构造函数的原型对象,并初始化构造函数,如果值则返回值。我们也会在后续的原型中介绍,new 是隐式原型继承,Object.create 是显式原型继承

    在这里,我们按实现 new 的方式来解读 return new F()。new F 后的实例的 __proto__ 指向的是 F.prototype,而这个值已经在第二步时指给了传来的 proto,所以就有了new F().__proto__ = proto

    a08a482b33e74d522dfff31c2f89f1e.jpg

    或许你还是不太清楚第三步,我们结合例子,就一目了然了

    var obj = Object.create({name: 'johan'})

    第三步的图解就成了这样:

    a43e4289d48caae8806477976238cff.jpg

    这样就成了, obj 继承自{name: johan} 这个对象,至于F.prototype = {name: 'johan'},在调用完 Object.create 之后,也因为没人使用 F 函数而被引擎当作垃圾回收了,遂成了obj.__proto__ = {name: 'johan'}

    如此「原型式继承」就被传承下来了

    其原理就是如此,简单来说,就是创建空(构造)函数,关联它的原型(实现继承)

    Object.create(null)

    在阅读源码时,常会看到 Object.create(null) ,用此初始化一个新对象,至于为什么用这个方法而不用 new Object 或者 {},是因为无论 new 还是字面量,都是继承自 Object 构造函数,而使用Object.create(null) ,能得到一个没有任何继承痕迹的对象

    var obj = Object.create(null)

    不信,你可以打印 obj 试试

    以上就是图解js中的Object.create方法(附代码实例)的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:segmentfault,如有侵犯,请联系admin@php.cn删除

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    自己动手写 PHP MVC 框架:点击学习

    快速了解MVC架构、了解框架底层运行原理

    专题推荐:Object.create
    上一篇:详解node中的包和包管理工具 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• 深入了解JavaScript中的Object(对象)• 一文讲解JS中Object对象一些操作方法(分享)• 一文了解CSS3中的新属性object-view-box• 聊聊JavaScript中怎么利用Object()函数创建对象• es6 中 object 有哪些方法 测试测试测试
    1/1

    PHP中文网