JavaScript对象属性设置和屏蔽技巧

关于JavaScript对象属性设置和屏蔽技巧,我从下面的几个方面详细阐述:

禁止增加属性

我们可以使用 Object.preventExtensions() 方法来禁止对象增加属性。如果我们尝试给一个被禁止增加属性的对象增加属性,就会失败并抛出错误。

const obj = { a: 1, b: 2 };
Object.preventExtensions(obj);

obj.c = 3; // TypeError: Cannot add property c, object is not extensible

冻结对象

我们可以使用 Object.freeze() 方法来冻结对象,从而防止对象的属性被修改和删除。如果我们尝试修改和删除一个被冻结的对象,就会失败并抛出错误。

const obj = { a: 1, b: 2 };
Object.freeze(obj);

obj.a = 3;   // TypeError: Cannot assign to read only property 'a' of object '#<Object>'
delete obj.b; // TypeError: Cannot delete property 'b' of #<Object> which is non-configurable and can't be deleted

// 可以通过 Object.isFrozen() 方法来检查一个对象是否被冻结
console.log(Object.isFrozen(obj)); // true

属性的设置和屏蔽

当我们给一个对象的属性设置了值后,我们可以通过屏蔽机制来控制访问该属性时返回的值。在访问属性时,JavaScript 引擎会检查该属性是否存在于对象本身上,如果不存在,它会沿着原型链一直查找到 Object.prototype 上。但是如果对象本身上存在该属性,无论该属性的值是什么,它都将遮盖原型链上该属性的值。

以下是一个示例:

const obj1 = { a: 1 };
const obj2 = { 
    b: 2, 
    get a() {
        return 3;
    } 
};

console.log(obj1.a); // 1
console.log(obj2.a); // 3

Object.setPrototypeOf(obj1, obj2); // 将 obj1 的原型设置为 obj2
console.log(obj1.a); // 1,因为 obj1 本身有 a 属性,不需要沿着原型链查找

从上面的示例可以看出,当我们通过 Object.setPrototypeOf() 方法将 obj1 的原型设置为 obj2 时,尽管 obj2 上的 a 属性的值为 3,但是在访问 obj1.a 时返回的是 obj1 本身上的 a 属性的值 1。原因是对象本身上的属性值会覆盖原型链上的同名属性值。可以通过在子对象中重新定义该属性来解决这个问题。

以下是通过在子对象中重新定义该属性的示例:

const obj1 = { a: 1 };
const obj2 = { 
    b: 2, 
    get a() {
        return 3;
    } 
};

console.log(obj1.a); // 1
console.log(obj2.a); // 3

Object.setPrototypeOf(obj1, obj2); // 将 obj1 的原型设置为 obj2
console.log(obj1.a); // 1,因为 obj1 本身有 a 属性,不需要沿着原型链查找

// 在 obj1 对象本身上重新定义 a 属性
Object.defineProperty(obj1, 'a', {
    value: 4,
    writable: true,
    configurable: true,
    enumerable: true
});

console.log(obj1.a); // 4
console.log(obj2.a); // 3

从上面的示例可以看出,在 obj1 对象本身上重新定义 a 属性后,再访问 obj1.a 时返回的是实例上的属性值 4,而 obj2 上的 a 属性的值仍然是 3。因为子对象中重新定义的属性会屏蔽原型链上的同名属性。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:JavaScript对象属性设置和屏蔽技巧 - Python技术站

(0)
上一篇 2023年5月27日
下一篇 2023年5月27日

相关文章

  • js 中 document.createEvent的用法

    下面是关于”js 中 document.createEvent的用法”的攻略: 什么是document.createEvent? document.createEvent()是 JavaScript 中的一个方法,它可以用于创建一个自定义事件对象。在 DOM 中,事件是与元素关联的行为,例如点击、滚动、鼠标移动等等。 以下是 document.createE…

    JavaScript 2023年5月27日
    00
  • JavaScript变量基本使用方法实例分析

    首先我们需要理解什么是JavaScript变量,变量是一个容器,用于存储数据值。在JavaScript中创建变量时需要使用var、let或const关键字进行声明。 声明变量 var变量 使用var声明的变量在声明的时候没有值,我们可以在后面对其进行赋值,也可以在声明时直接赋值。var有全局作用域和函数作用域两种,而且var可以被重复声明。 var a = …

    JavaScript 2023年5月27日
    00
  • 基于JS实现的消消乐游戏的示例代码

    下面是详细讲解“基于JS实现的消消乐游戏的示例代码”的完整攻略。 1. 简介 消消乐游戏是一款经典的益智类游戏,是一种基于图形匹配的消除游戏,在游戏中需要将相同类型的方块匹配消除,以获得更高的分数。 基于JS实现的消消乐游戏的示例代码,主要使用了HTML、CSS、JavaScript等技术,通过使用HTML来创建游戏的页面布局和界面元素,使用CSS来对页面布…

    JavaScript 2023年6月11日
    00
  • javascript unicode与GBK2312(中文)编码转换方法

    下面是详细讲解“javascript unicode与GBK2312(中文)编码转换方法”的完整攻略。 了解Unicode与GBK2312编码 在进行编码转换前,我们需要先了解所涉及的两种编码方式:Unicode和GBK2312。 Unicode是国际标准化组织制定的国际编码标准,它为世界上所有的字符规定了统一的编码,包括字母、数字、标点符号、各国文字等。U…

    JavaScript 2023年5月20日
    00
  • 指定js可访问其它域名的cookie的方法

    指定js可访问其它域名的cookie的方法又称为“跨域访问”,一般涉及到前后端的交互,可以使用以下两种方法解决: 服务器端设置Access-Control-Allow-Origin响应头 在服务器端的响应头中设置Access-Control-Allow-Origin字段为指定的域名或所有域名(*),可以允许跨域访问,具体代码如下: header("…

    JavaScript 2023年6月11日
    00
  • JS实现的系统调色板完整实例

    JS实现的系统调色板完整实例攻略 一、目标 本教程将介绍如何使用HTML、CSS和JavaScript实现一个系统调色板。该调色板将由六个滑块组成,每个滑块对应一个颜色通道。通过拖动滑块,可动态改变色彩输出。最后,我们将为该调色板添加一个显示颜色名称和十六进制代码的区域,以便用户了解当前所选颜色的相关信息。 二、步骤 1. HTML结构 首先,创建一个HTM…

    JavaScript 2023年6月10日
    00
  • 实例讲解Cookies欺骗与session欺骗入侵

    实例讲解Cookies欺骗与session欺骗入侵是一种常见的网络攻击手段,攻击者通过伪造Cookies或者Session,绕过网站的身份认证机制,获取其他用户的登录凭证或者直接盗取用户数据。下面我们就来详细讲解这个攻击手段的攻击方式、防御措施以及两条常见攻击示例。 什么是Cookies欺骗与session欺骗入侵? 1. Cookies欺骗入侵 Cooki…

    JavaScript 2023年6月11日
    00
  • 分享一个自己写的table表格排序js插件(高效简洁)

    以下是“分享一个自己写的table表格排序js插件(高效简洁)”的完整攻略。 简介 这个table表格排序js插件是基于原生JS编写的,能够高效、简洁地为网页中的table表格添加排序功能。插件使用方便,只需要在HTML中添加相应的class和data-属性即可,不需要引入其他框架或库。 使用方法 引入插件 首先,需要在HTML中引入插件的JS文件: &lt…

    JavaScript 2023年6月10日
    00
合作推广
合作推广
分享本页
返回顶部