首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

JS操作对象属性(获取、添加、删除、修改对象属性

如果指定的属性名在对象中不存在,则执行添加操作;如果在对象中存在同名属性,则执行修改操作。...使用点语法 使用点语法可以快速读写对象属性,点语法左侧是引用对象的变量,右侧是属性名。 示例1 下面示例定义对象 obj,包含属性 x,然后使用点语法读取属性 x 的值。...如果读取未定义的属性,则返回值都是 undefined。 删除属性 使用 delete 运算符可以删除对象属性。 示例 下面示例使用 delete 运算符删除指定属性。...var obj = {x : 1}; //定义对象delete obj.x; //删除对象属性xconsole.log(obj.x); //返回undefined 当删除对象属性之后,不是将该属性值设置为...如果使用 for/in 语句枚举对象属性,只能枚举属性值为 undefined 的属性,但不会枚举已删除属性。 使用方法 方法也是函数,当函数被赋值给对象属性,就被称为方法。

15.1K00

js对象属性

前言 相信对于对象属性大家都或多或少的知道一些,那么本文从属性说开去,看看大家对属性的了解是否有遗漏的部分。...均为布尔型,默认为true,分别代表可删除、可枚举、可修改,第四个为true 访问器属性 configurable,enumerable,getter,setter 后面两个是非必须的 虽然似乎说的很明白...(let p in zhangsan){ console.log(zhangsan.hasOwnProperty(p),`${p}:${zhangsan[p]}`) } 参考代码 codepen关于js...对象自身可枚举,不含 Symbol 属性 Object.getOwnPropertyNames(obj) 返回一个数组,包含对象自身的所有属性(不含 Symbol 属性,但是包括不可枚举属性)的键名 对象自身...对象自身,全部属性 属性中的this是什么 来源 指向 对象 对象自身 构造函数 返回新对象 原型 原型 纯函数调用 外部环境全局,浏览器或者node 访问器get,set使用 一般我们也用不到这个

15.6K10

深入 JS 对象属性

属性决定JS对象的状态,本文章主要分析这些属性是如何工作的。 JS几种不同的属性 JS有三种不同的属性:数据属性,访问器属性和内部属性。...如果设为false,将阻止某些操作改写该属性,比如无法删除属性,也不得改变该属性属性描述对象(value属性除外)。也就是说,configurable属性控制了属性描述对象的可写性。 3....每个属性都有自己对应的属性描述对象,保存该属性的一些元信息。下面是值为123属性描述对象的一个例子。...(自有属性指的是直接赋予该对象属性,不需要从原型链上进行查找的属性) obj:需要查找的目标对象 prop:目标对象属性名称 var o, d; o = { get foo() { return...enumerable: false, configurable: false } > Object.getOwnPropertyDescriptor(obj, "toString") undefined 创建,删除和定义属性仅影响原型链中的第一个对象

8.5K50

JS 对象属性相关--检查属性、枚举属性

1.删除属性 delete运算符可以删除对象属性 delete person.age //即person不再有属性age delete person['age'] //或者这样 delete只是断开属性和宿主对象的联系...console.log(a.p.x); //TypeError a.p is undefined console.log(a.p); //undefined console.log(b.x); //1 delete只能删除自有属性...,不能删除继承属性(要删除继承属性必须从定义这个属性的原型对象删除它,当然,这会影响到所有继承来自这个原型的对象) function inherit(p){ if(p == null){...y; //这样可以删除 function f(){ } delete this.f; //不能删除 2.检测属性 使用 “in" in 运算符希望它的左操作数是一个字符串或者可以转换为字符串,希望它的右操作数是一个对象...Date);//true console.log(d instanceof Object);//true console.log(d instanceof Number);//false 拓展2: 对象的类属性是一个字符串

5.8K20

JS对象属性排序小技巧

前面我们讲到数组对象去重的时候,如果由于对象里面的内容是一样,但是属性位置不一样,从而导致我们可能出现无法去重,虽然JSON.stringify()的第二个参数能够自行添加属性到数组里面,但有可能出现我们并不知道对象具体有哪些属性...后来我搜索相关文章,发现了一个很有用的代码,能够自动对属性进行排序,分享给你们。...如下: JSON.stringify(obj, Object.keys(obj).sort()) 当我们使用上面这个Object.keys(obj).sort()之后,并不需要像上一篇手动加入属性组。...(o) { return JSON.stringify(Object.keys(o).sort().reduce((r, k) => (r[k] = o[k], r), {})); } 完整的数组对象去重如下...,map方法是一个遍历方法,返回遍历结果组成的数组.将unique对象的键名还原成对象数组 return JSON.parse(u); }) return arr; } function

3.3K20

js对象属性的getter和setter

故温故一遍getter和setter定义属性的方法。 通过对象字面量定义get和set方法 有个注意的地方,get与set的函数体都不能再定义本身该属性,否则执行的时候会陷入死循环,抛出栈溢出。...在对象字面量中,同一个属性不能有两个get,也不能既有get又有属性键值(不允许使用 { get x() { }, get x() { } } 和 { x: …, get x() { } } ) 在同一个对象中...Cannot both specify accessors and a value or writable attribute, # //删除writable属性就可以了 如何实现数据双向绑定...双向数据绑定底层的思想非常的基本,它可以被压缩成为三个步骤: 1.我们需要一个方法来识别哪个UI元素被绑定了相应的属性 2.我们需要监视属性和UI元素的变化 3.我们需要将所有变化传播到绑定的对象和元素...}); } catch (error) { // IE8+ 才开始支持defineProperty,这也是Vue.js

3.1K50

Vue删除对象属性需要注意的地方

作为一款很火的开源框架,应用也越来越广,好了直接入主题, var test = new Vue({ el: '#vue_test', data: { remarks: 'Hello Vue.js...} }) 上面的一段代码是我们使用Vue时常用的,这样remarks就成为创建的Vue对象的一个属性,如果我们要添加Vue属性可以通过set方法: create_model....$set("xx",xx); 删除属性则可以使用vue的delete方法: Vue.delete( object, key ) 但是需要注意的是下面这种情况: ....pg.remarks" type="text" class="input-large"> 笔者在这里要说的是上面标红的部分,我们在这里上面代码创建了test的vue对象...,而pg是该vue对象的一个属性,只不过pg这个属性是一个对象,针对这种情况如果需要删除remarks属性的话则需要通过下面的方式: Vue.delete( test.

90010

js对象属性描述符详细介绍

属性描述符是 ECMAScript 5 新增的语法,它其实就是一个内部对象,用来描述对象属性的特性。属性描述符的结构在 JavaScript 中,对象属性描述符用于描述和定义对象属性的特性。...以下是常见的属性描述符及其作用:configurable:表示属性是否可以被删除或修改特性。如果设置为 false,则不能删除或修改该属性的特性。默认为 true。...示例 3configurable 可以禁止修改属性描述符,当其值为 false 时,value、writable、enumerable 和 configurable 禁止修改,同时禁止删除属性。...Object.preventExtensions:阻止为对象添加新的属性。Object.seal:阻止为对象添加新的属性,同时也无法删除属性。...等价于属性描述符的 configurable 属性设为 false。注意,该方法不影响修改某个属性的值。Object.freeze:阻止为一个对象添加新属性删除属性、修改属性值。

15010
领券