iis服务器助手广告
返回顶部
首页 > 资讯 > 精选 >js中的Object.create方法怎么使用
  • 681
分享到

js中的Object.create方法怎么使用

2023-07-04 15:07:09 681人浏览 八月长安
摘要

这篇文章主要介绍“js中的Object.create方法怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“js中的Object.create方法怎么使用”文章能帮助大家解决问题。ECMAScri

这篇文章主要介绍“js中的Object.create方法怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“js中的Object.create方法怎么使用”文章能帮助大家解决问题。

ECMAScript 5 新增了 Object.create() 方法将原型式继承的概念规范化

用法

var obj = Object.create({name: 'johan', age: 23}) // obj 继承了属性name 和 agevar 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;

js中的Object.create方法怎么使用

F.prototype = proto

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

js中的Object.create方法怎么使用

return new F()

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

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

js中的Object.create方法怎么使用

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

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

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

js中的Object.create方法怎么使用

这样就成了, 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)

关于“js中的Object.create方法怎么使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网精选频道,小编每天都会为大家更新不同的知识点。

--结束END--

本文标题: js中的Object.create方法怎么使用

本文链接: https://www.lsjlt.com/news/346381.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • js中的Object.create方法怎么使用
    这篇文章主要介绍“js中的Object.create方法怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“js中的Object.create方法怎么使用”文章能帮助大家解决问题。ECMAScri...
    99+
    2023-07-04
  • js中Object.create实例用法详解
    1、用Object.create()方法创建新对象,并使用现有对象提供新对象的proto。 2、提供两个参数,第一个是新创建的原型对象,第二个是为新创建的对象添加属性的对象。 实例 ...
    99+
    2024-04-02
  • 图解js中的Object.create方法(附代码实例)
    ECMAScript 5 新增了 Object.create() 方法将原型式继承的概念规范化【推荐学习:JavaScript视频教程】用法var obj = Object.create({name: 'johan', ag...
    99+
    2022-11-25
    Object.create
  • JavaScript中关于Object.create()的用法
    JavaScript的Object.create()方法 ES5定义了一个名为Object.create()的方法,它创建一个对象,其中第一个参数就是这个对象的原型,Object.c...
    99+
    2023-02-10
    JavaScript的Object.create用法 Object.create() JS Object.create()
  • js中的Math方法怎么使用
    这篇“js中的Math方法怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“js中的M...
    99+
    2024-04-02
  • js中的Array.reduce方法怎么使用
    这篇文章主要介绍“js中的Array.reduce方法怎么使用”,在日常操作中,相信很多人在js中的Array.reduce方法怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”js中的Array.red...
    99+
    2023-07-05
  • JS中hasOwnProperty()方法怎么使用
    JavaScript中的hasOwnProperty()方法用于检查一个对象是否具有特定的属性。它是通过原型链来判断的,只有当对象自...
    99+
    2023-09-13
    JS
  • js中history.back方法怎么使用
    在JavaScript中,可以使用history.back()方法来返回用户上一页的浏览历史记录。 使用方法如下: history....
    99+
    2024-02-29
    js
  • js中Window clearTimeout()方法怎么使用
    在JavaScript中,window.clearTimeout()方法用于取消之前通过window.setTimeout()方法设...
    99+
    2023-09-22
    js
  • js中Window setTimeout()方法怎么使用
    在JavaScript中,`setTimeout()`方法用于延迟执行一个函数或者一段代码。它接受两个参数:第一个参数是要执行的函数...
    99+
    2023-10-10
    js
  • js中Window location.reload()方法怎么使用
    在JavaScript中,可以使用`window.location.reload()`方法来重新加载当前页面。该方法不接受任何参数。...
    99+
    2023-10-10
    js
  • join()方法怎么在js中使用
    今天就跟大家聊聊有关join()方法怎么在js中使用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1、说明join方法能把数组序列转换为字符串, join方法后面可以跟match方法...
    99+
    2023-06-15
  • JS的String.raw方法怎么使用
    本篇内容介绍了“JS的String.raw方法怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!String.rawString.raw...
    99+
    2023-07-02
  • js的slice方法怎么使用
    JavaScript中的slice()方法用于从数组、字符串或类数组对象中提取指定范围的元素,并返回一个新的数组。语法:array....
    99+
    2023-08-29
    js slice
  • JS的replace方法怎么使用
    replace方法是用来替换字符串中指定的子字符串并返回一个新的字符串。它接受两个参数,第一个参数是要被替换的子字符串或正则表达式,...
    99+
    2024-03-01
    js
  • js中matchAll()方法的使用方法
    本篇内容介绍了“js中matchAll()方法的使用方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!说明matchAll()方法返回一个包...
    99+
    2023-06-20
  • js中repeat()的使用方法
    本篇内容介绍了“js中repeat()的使用方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、返回一个新字符串,表示将原字符串重复n次。...
    99+
    2023-06-20
  • js中arguments的使用方法
    本篇内容主要讲解“js中arguments的使用方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“js中arguments的使用方法”吧!说明当不确定传递了多少参数时,可以使用arguments...
    99+
    2023-06-20
  • JS中Object.assign方法的使用
    最在做项目过程中,大量的使用了Object.assign方法,发现这个还是挺好使用的,现在总结下Object.assign的基本使用。 一、基本语法 Object.assign(ta...
    99+
    2024-04-02
  • js中Array.filter()方法的使用
    这篇文章主要讲解了“js中Array.filter()方法的使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“js中Array.filter()方法的使用”吧!1、用filter()方法返回...
    99+
    2023-06-20
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作