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])
        }
    }
    
相关推荐
明月_清风38 分钟前
打字机效果优化:用 requestAnimationFrame 缓冲高频文字更新
前端·javascript
明月_清风39 分钟前
Markdown 预解析:别等全文完了再渲染,如何流式增量渲染代码块和公式?
前端·javascript
程序猿的程14 小时前
开源一个 React 股票 K 线图组件,传个股票代码就能画图
前端·javascript
大雨还洅下15 小时前
前端JS: 虚拟dom是什么? 原理? 优缺点?
javascript
唐叔在学习15 小时前
[前端特效] 左滑显示按钮的实现介绍
前端·javascript
青青家的小灰灰15 小时前
深入理解事件循环:异步编程的基石
前端·javascript·面试
前端Hardy16 小时前
HTML&CSS&JS:打造丝滑的3D彩纸飘落特效
前端·javascript·css
前端Hardy16 小时前
HTML&CSS&JS:丝滑无卡顿的明暗主题切换
javascript·css·html
UIUV18 小时前
node:child_process spawn 模块学习笔记
javascript·后端·node.js
烛阴19 小时前
Three.js 零基础入门:手把手打造交互式 3D 几何体展示系统
javascript·webgl·three.js