JavaScript 对象方法及其扩展
创始人
2024-04-17 16:31:37

JavaScript 对象方法及其扩展

Object.assign(target,source1,source2…)

作用:从左到右将多个对象合并到target中,并返回target
特点

  1. 如果属性值为对象使用等号进行赋值(浅拷贝)
  2. 只会拷贝源对象自身的并且可枚举的属性到目标对象身上。
  3. 会跳过那些值为 null 或 undefined 的源对象
    使用场景 为属性指定默认值
const DEFAULTS = {logLevel: 0,outputFormat: 'html'
};
//options对象是用户提供的参数。
function processContent(options) {options = Object.assign({}, DEFAULTS, options);console.log(options);// ...
}

Object.is(参数1,参数2)

作用:类似===,比较参数1参数2是否相等
特点

  1. 类似===左右两边不会自动进行类型转换
  2. 解决了===存在的问题
    • NaN等于自身
    • +0和-0不相等
console.log(Object.is(0,-0)) //false
console.log(Object.is(NaN,NaN))//true
Object.is({}, {})// false

Object.keys(obj)/Object.values(obj)/Object.entries(obj)

Object.keys(obj):返回给定对象的自身可枚举属性组成的数组
Object.values(obj):返回给定对象的自身可枚举属性对应的属性值组成的数组
-Object.entries(obj):返回由对象身可枚举键值对组成的二维数组

使用场景:将对象转为真正的Map结构

const obj = { foo: 'bar', baz: 42 };
const map = new Map(Object.entries(obj));
map // Map { foo: "bar", baz: 42 }

Object.fromEntries(可迭代对象) ES2019

作用:根据键值对组成的列表,创建一个对象

Object.fromEntries()方法是Object.entries()的逆操作,用于将一个键值对数组转为对象。

Object.fromEntries([['foo', 'bar'],['baz', 42]
])
// { foo: "bar", baz: 42 }

Object.getOwnPropertyDescriptors()

作用:返回对象自身+不可枚举+Symbol类型属性的信息组成的一个对象。主要是为了解决Object.assign()无法正确拷贝get属性和set属性的问题。

const obj = {foo: 123,get bar() { return 'abc' }
};Object.getOwnPropertyDescriptors(obj)
//  { foo:
//    { value: 123,
//      writable: true,
//      enumerable: true,
//      configurable: true },
//   bar:
//    { get: [Function: get bar],
//      set: undefined,
//      enumerable: true,
//      configurable: true } }

使用场景:完整的拷贝一个对象

Object.setPrototypeof()/Obejct.setPrototypeOf()

Object.setPrototypeOf(对象a,对象b):设置对象a的__proto__指向对象b
Object.getPrototypeOf(对象):获取指定对象的__proto__指向的值,没有返回null

相关内容

热门资讯

苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
tag是什么意思 tab是什么... 一、B端基础控件的认识控件一词,直译的话可以翻译成 “用来控制的元件”,是我们对 B 端系统进行信息...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
tag是什么意思 tab是什么... 一、B端基础控件的认识控件一词,直译的话可以翻译成 “用来控制的元件”,是我们对 B 端系统进行信息...
苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...