ES6--》对象扩展方法

这篇具有很好参考价值的文章主要介绍了ES6--》对象扩展方法。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

对象扩展

name 属性

属性的遍历

super关键字

Object.is()

Object.assign()

Object.getOwnPropertyDescriptors()

Object.setPrototypeOf()

Object.getPrototypeOf()

Object.keys()、Object.values、Object.entries()、Object.fromEntries()

Object.hasOwn()


对象扩展

本文简单介绍以下ES6对对象新增的方法:

name 属性

函数的name属性,返回函数名。对象方法也是函数也有name属性。

<script>
    const obj = {
        name:'张三',
        age:18,
        sayName(){
            console.log('hello world');
        }
    }
    console.log(obj.sayName.name);//sayName
</script>

如果对象方法使用取值函数(getter)和存值函数(setter),需要该方法的属性的描述对象在对象get和set属性上面,返回值是方法名前加上get和set。

<script>
    const obj = {
        get foo(){},
        set foo(x){}
    }
    const descriptor = Object.getOwnPropertyDescriptor(obj, 'foo');
    console.log(descriptor.get.name);//get foo
</script>

有两种特殊情况:

<script>
    // Function构造函数创造的函数,name属性返回anonymous。
    console.log((new Function()).name);//anonymous

    // bind方法创造的函数,name属性返回bound加上原函数的名字。
    var doSomething = function(){}
    console.log(doSomething.bind().name);//bound doSomething
</script>

属性的遍历

ES6中一共有 5 种方法可以遍历对象的属性。

(1) for...in

循环遍历对象自身属性和继承的可枚举属性

(2)Object.keys(obj)

返回一个数组,包括对象自身的(不含继承的)所有可枚举属性(不含Symbol属性)的键名

(3)Object.getOwnPropertyNames(obj)

返回一个数组,包含对象自身的所有属性(不含Symbol属性,但是包括不可枚举属性)的键名

(4)Object.getOwnPropertySymbols(obj)

返回一个数组,包含对象自身的所有Symbol属性的键名

(5)Reflect.ownKeys(obj)

返回一个数组,包含对象自身的(不含继承的)所有键名,不管键名是Symbol或字符串,也不管是否可枚举。

super关键字

和this关键字总是指向函数所在的当前对象一样,ES6新增了另一个类似的关键字super,指向当前对象的原型对象。

下面代码中,super.say() 指向原型对象 obj 的say方法,但是绑定的this却还是当前对象obj,因此输出的结果不是hello而是world。

<script>
    const person = {
        x:'hello',
        say(){
            console.log(this.x);
        }
    }
    const obj = {
        x:'world',
        say(){
            super.say()
        }
    }
    Object.setPrototypeOf(obj,person)//,该对象将指定对象的原型(即内部[[Prototype]]属性)设置为另一个对象或为null。
    console.log(obj.say());//world
</script>

Object.is()

用来比较两个值是否严格相等,与严格比较运算符(===)的行为基本一致。

<script>
    var obj = {
        name:'张三',
        name1:'张三',
        gender:'男',
        age:18,
        say(){
            console.log('hello world');
        }
    }
    console.log(Object.is(obj.name,obj.name1));//true
    console.log(Object.is(1,1));//true
    
    // Object.is() 和 === 的区别在于以下特殊例子
    console.log(+0 === -0);//true
    console.log(Object.is(+0,-0));//false
    console.log(NaN === NaN);//false
    console.log(Object.is(NaN,NaN));//true
</script>

Object.assign()

用于对象的合并,将源对象所有可枚举的属性,复制到目标对象上。

<script>
    var obj = {
        a:1,
        b:2,
        c:'我是c'
    }
    var obj1 = {
        a:2, //当目标对象与源对象有同名属性,或多个源对象有同名属性,则后面的属性会覆盖前面的属性
        d:3,
        e:'我是e'
    }
    // console.log(Object.assign(target, source1, source2));
    console.log(Object.assign(obj,obj1));
</script>

用到对象合并我们可以就会遇到一些问题了,请看如下例子:

<script>
    // 参数不是对象,则会先转换成对象
    console.log(typeof Object.assign(2)); //object

    // null和undefined无法转对象,作为目标对象为false,但是作为源对象为true的
    // console.log(Object.assign(null,2));//报错提醒 Cannot convert undefined or null to object
    // console.log(Object.assign(2,null));//没报错

    // 其他类型像数值、字符串、布尔值虽然不会报错,但只有字符串会以数组形式拷入目标对象,其他值不会产生效果
    const x = 'abc'
    const y = 123
    const z = true
    console.log(Object.assign({},x));//{0: 'a', 1: 'b', 2: 'c'}
    console.log(Object.assign({},y));//{}
    console.log(Object.assign({},z));//{}
</script>

在使用这个ES6新增的方法时,应该注意以下内容:

<script>
    // Object.assign()实行的是浅拷贝,如果源对象发生任何变化,都会反映到目标对象上
    const obj1 = {a:1,b:2,c:{d:3}}
    const obj2 = Object.assign({},obj1)
    obj1.c.d = 3.14
    console.log(obj2.c.d);

    // Object.assign()可以用来处理数组
    console.log(Object.assign([1,2,3],[4,5]));// [4, 5, 3]

    // Object.assign()可以用来对取值函数进行处理,求值之后再处理
    const a = {
        get foo(){
            return 1
        }
    }
    console.log(Object.assign({},a));//{foo: 1}
</script>

Object.getOwnPropertyDescriptors()

返回指定对象所有自身属性(非继承属性)的描述对象。

<script>
    const obj = {
        num:12,
        get say(){
            return 'hello world'
        }
    }
    console.log(Object.getOwnPropertyDescriptors(obj));
</script>

es6 对象扩展,# JavaScript,es6,javascript,前端,ecmascript

Object.setPrototypeOf()

方法作用与__proto__相同,用来设置应该对象的原型对象(prototype),返回参数对象本身。

<script>
    let proto = {}
    let obj = {x:10}
    Object.setPrototypeOf(obj,proto)
    proto.y = 11
    proto.z = 12

    console.log(obj.x);//10
    console.log(obj.y);//11
    console.log(obj.z);//12
</script>

Object.getPrototypeOf()

方法用于读取一个对象的原型对象,与Object.setPrototypeOf()方法配套。

<script>
    function foo(){}
    const f = new foo()
    console.log(Object.getPrototypeOf(f) === foo.prototype);//true
    Object.setPrototypeOf(f,Object.prototype)//修改原型对象
    console.log(Object.getPrototypeOf(f) === foo.prototype);//false
</script>

Object.keys()、Object.values、Object.entries()、Object.fromEntries()

三种方法都是返回一个数组,之间的区别请看如下:

<script>
    // Object.keys() 返回所有可遍历的键名
    var obj = {aa:1,bb:'我是b',cc:2}
    console.log(Object.keys(obj));//['aa', 'bb', 'cc']

    // Object.values() 返回所有可遍历的属性的键值,键值排序按属性名数值大小排序i
    const obj1 = {12:'a',1:'b',18:'c'}
    console.log(Object.values(obj1));//['b', 'a', 'c']

    // Object.entries() 返回所有可遍历属性的键值对数组
    const obj2 = {1:'a','b':2,3:'c'}
    console.log(Object.entries(obj2));//[['1', 'a'],['3', 'c'],['b', 2]]

    // Object.fromEntries() 与 Object.entries()操作相反,将一键值对数组转为对象。
    console.log(Object.fromEntries([
        ['1', 'a'],
        ['3', 'c'],
        ['b', 2]
    ]));//{1: 'a', 3: 'c', b: 2}
</script>

Object.hasOwn()

方法可以判断某个属性是否为原生属性,接受两个参数,第一个是参数是要判断的对象,第二个是属性名。文章来源地址https://www.toymoban.com/news/detail-832186.html

<script>
    const obj = Object.create({a:12});
    obj.b = 34
    // 对象obj的属性a是继承属性,属性b是原生属性。
    console.log(Object.hasOwn(obj,'a'));//false
    console.log(Object.hasOwn(obj,'b'));//true
</script>

到了这里,关于ES6--》对象扩展方法的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • ES6对象扩展

    ES6对象扩展是指在ES6中新增的一些对象属性和方法,包括对象属性的简写、计算属性名、对象方法的简写、对象的可迭代性、拓展运算符等。 下面是一些常用的ES6对象扩展: 对象属性的简写 ES6中,当对象的属性名和赋值变量名相同时,可以简写属性名称,例如: 这里的na

    2024年02月07日
    浏览(27)
  • JavaScript ES6实现继承

    1 对象的方法补充 2 原型继承关系图 3 class方式定义类 4 extends实现继承 5 extends实现继承 6 多态概念的理 function 创建的名称如果开头是大写的,那这个创建的不是函数,是创建了类。 可以把class创建的类当做是function创建的类的一种语法糖。但是在直接使用的方面是有不同之处

    2024年02月16日
    浏览(34)
  • JavaScript 之 ES6 新特性

    在ES6中,模块化成为了JavaScript的标准特性。ES6模块化提供了一种更加优雅和可维护的方式来组织和管理JavaScript代码,可以有效地避免全局变量的污染和命名冲突的问题。以下是ES6模块化的一些主要特性: 导出(export): 可以通过 export 将一个变量、函数或类导出为一

    2024年02月07日
    浏览(37)
  • JavaScript Es6_3笔记

    了解构造函数原型对象的语法特征,掌握 JavaScript 中面向对象编程的实现方式,基于面向对象编程思想实现 DOM 操作的封装。 了解面向对象编程的一般特征 掌握基于构造函数原型对象的逻辑封装 掌握基于原型对象实现的继承 理解什么原型链及其作用 能够处理程序异常提升程

    2024年02月11日
    浏览(38)
  • 【ES6】JavaScript中的Symbol

    Symbol是JavaScript中的一种特殊的、不可变的、不可枚举的数据类型。它通常用于表示一个唯一的标识符,可以作为对象的属性键,确保对象的属性键的唯一性和不可变性。 Symbol.for()是Symbol的一个方法,它用于创建一个已经注册的Symbol对象。当使用Symbol.for()创建Symbol对象时,会

    2024年02月10日
    浏览(32)
  • JavaScript版本ES5/ES6及后续版本

    Brendan Eich在短短10天内创建了JavaScript的第一个版本。它被称为摩卡,但已经具备了现代JavaScript的许多基本特性! 为了吸引Java开发人员,Mocha先是更改为LiveScript,然后又更改为JavaScript然而,JavaScript与Java几乎没有任何关系; 微软推出了IE,从网景复制JavaScript,并称之为JScript; 由

    2024年02月13日
    浏览(35)
  • JavaScript之ES6高级语法(一)

    本文是我在学习过程中记录学习的点点滴滴,目的是为了学完之后巩固一下顺便也和大家分享一下,日后忘记了也可以方便快速的复习。 今天学习的主要是关于ES6新语法知识的理解和应用 栈负责存放简单数据类型,堆负责存放复杂数据类型,但是复杂数据类型会把内容存在

    2024年02月09日
    浏览(40)
  • JavaScript:ES6中类与继承

    在JavaScript编程中,ES6引入了一种更现代、更清晰的方式来定义对象和实现继承,那就是通过类和继承机制。本文将以通俗易懂的方式解释ES6中类与继承的概念,帮助你更好地理解和应用这些特性。 1. 类的创建与使用 类是一种模板,用于创建对象。在ES6中,我们可以使用 cl

    2024年02月13日
    浏览(31)
  • 【Javascript】ES6新增之类的认识

    在现代编程语言中,类是面向对象编程范式中的核心概念之一。 与函数类似,类本质上是一种特殊的函数,它允许我们将数据和操作封装在一起,以创建具有共同行为和状态的对象。 在类的世界里,我们有类表达式和类声明,它们各自具有自己的特性和用途。 ✨ 类本质上是

    2024年02月13日
    浏览(30)
  • 【ES6】 JavaScript 中的Object.assign

    Object.assign() 是 JavaScript 中的一个方法,它用于复制源对象的所有可枚举属性到目标对象。该方法会返回目标对象。 这是其基本用法: 在这个例子中,source 对象的所有可枚举属性都被复制到了 target 对象。 需要注意的是,Object.assign() 是浅复制(shallow copy),意味着如果源对

    2024年02月10日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包