JavaScript高级(十一)--对象方法Object

对象方法的补充

Object.create()

使用指定的原型对象和属性创建一个新对象。

返回值:一个新对象,带着指定的原型对象和属性。

javascript 复制代码
    var obj = {
      name: "why",
      age: 18
    }
    
    // 指定新对象的原型为obj
    var info = Object.create(obj, {
      address: {
        configurable: true,
        writable: true,
        enumerable: true,
        value: "beijing"
      }
    })

    console.log(info)
Object.assign()

通过复制一个或多个对象来创建一个新的对象。

javascript 复制代码
    const target = { a: 1, b: 2 };
    const source = { c: 4, d: 5 };

    // 原对象target也会发生变化
    // const res = Object.assign(target, source)

    // 解决方案1
    const res1 = Object.assign({}, target, source)
   
    // 解决方案2
    const res2 = {...target, ...source}
Object.defineProperty()

给对象添加一个属性并指定该属性的配置

javascript 复制代码
    const obj = {};

    Object.defineProperty(obj, "address", {
      value: "深圳",
      configurable: true,
      enumerable: true,
      writable: true
    })
Object.defineProperties()

给对象添加多个属性并分别指定它们的配置。

javascript 复制代码
    const obj = {};

    Object.defineProperties(obj, {
      address: {
        value: "深圳",
        configurable: true,
        enumerable: true,
        writable: true
      },
      name: {
        value: "malong",
        configurable: true,
        enumerable: true,
        writable: true
      }
    })
Object.freeze()

冻结对象:其他代码不能删除或更改任何属性。

javascript 复制代码
    var obj = {
        name: "malong"
    };
    
    Object.freeze(obj)
Object.prototype.hasOwnProperty()

返回一个布尔值,用于表示一个对象自身是否包含指定的属性,该方法并不会查找原型链上继承来的属性。

javascript 复制代码
    var obj = {
        name: "zhangsan"
    }
     
    for(var key in obj){
        if(obj.hasOwnProperty(key)){
            console.log(obj[key])
        }
    }
    
相关推荐
charlie1145141916 分钟前
Android开发——初步了解AndroidManifest.xml
android·xml·开发语言·学习·安卓·安全架构
Edward.W19 分钟前
用 Go + HTML 实现 OpenHarmony 投屏(hdckit-go + WebSocket + Canvas 实战)
开发语言·后端·golang
努力努力再努力wz32 分钟前
【c++进阶系列】:万字详解AVL树(附源码实现)
java·运维·开发语言·c++·redis
CHANG_THE_WORLD1 小时前
C++并发编程指南 std::promise 介绍与使用
java·开发语言·c++·promise
egoist20231 小时前
[linux仓库]性能加速的隐形引擎:深度解析Linux文件IO中的缓冲区奥秘
linux·运维·开发语言·缓存·缓冲区
Dear.爬虫1 小时前
Golang的协程调度器原理
开发语言·后端·golang
Mintopia1 小时前
实时 AIGC:Web 端低延迟生成的技术难点与突破
前端·javascript·aigc
Mintopia1 小时前
Next.js 性能优化双绝:Image 与 next/font 的底层修炼手册
前端·javascript·next.js
小菜全1 小时前
使用UniApp实现下拉框和表格组件页面
开发语言·前端·javascript·elementui·前端框架·html
编码浪子1 小时前
趣味学RUST基础篇(构建命令行程序1)
开发语言·后端·rust