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

JS篇(021)-for in、Object.keys和Object.getOwnPropertyNames对属性遍历有什么区别

答案: * for in 会遍历自身及原型链上可枚举属性 * Object. keys 会将对象自身可枚举属性 key 输出 * Object. getOwnPropertyNames会将自身所有的属性...key 输出 解析: ECMAScript 将对象属性分为两种:数据属性和访问器属性。...enumerable: true, configurable: true } }); // parent继承自Object.prototype,有一个可枚举属性a(enumerable.... keys console.log(Object.keys(child)); // ["b"] // Object.keys 会将对象自身可枚举属性key输出 3、Object. getOwnPropertyNames...console.log(Object.getOwnPropertyNames(child)); // ["b","c"] // 会将自身所有的属性key输出 [参与互动](https://github.com

1.3K20

ECMAScript5 Object属性方法

true} Object.getOwnPropertyNames 获取所有的属性名,不包括prototype中属性,返回一个数组 console.log(Object.getOwnPropertyNames...(o)); //["age", "sex"] 例子中可以看到prototype中name属性没有获取到 Object.keys() 和getOwnPropertyNames方法类似,但是获取所有的可枚举属性...Object.isExtensible 方法用于锁住对象属性,使其不能够拓展,也就是不能增加新属性,但是属性值仍然可以更改,也可以把属性删除,Object.isExtensible用于判断对象是否可以被拓展...方法用于把对象密封,也就是让对象既不可以拓展也不可以删除属性(把每个属性configurable设为false),单数属性值仍然可以修改,Object.isSealed由于判断对象是否被密封 Object.seal.../ Object.isFrozen 终极神器,完全冻结对象,在seal基础上,属性值也不可以修改(每个属性wirtable也被设为false) Object.freeze(o); o.age = 25

72340

这次彻底理解了Object这个属性

1.实例化Object对象 实例化Object对象方式有两种:使用Object构造器和使用对象字面量。...如果我们只是想获取一个对象中所有属性名,可以使用Object.keys()方法。该方法会以数组形式返回所有的属性名。...如果我们向改变属性特性,可以使用Object.defineProperty()方法。该方法接受3个参数:拥有被修改属性对象、被修改属性名、包含描述特性对象。...Object.defineProperty(),定义多个属性使用Object.defineProperties(),这个方法接受2个参数,第一个是属性所属对象,第二个是包含被定义属性对象。...获取属性内部特性方法有两个:Object.getOwnPropertyDescriptor()和Object.getOwnPropertyDescriptors()。

66720

js Object.defineProperty()详解

要修改属性默认特性,就必须使用 Object.defineProperty()方法 ;在了解Object.defineProperty()之前,需要先明白对象属性一些特性,明白了这些特性之后,对Object.defineProperty...(object,prop,descript) Object.defineProperty()接收三个参数: object: 要添加或者修改属性目标对象; prop: 要定义或修改属性名称; descript...: 是一个对象,里面是我们上述对象属性特性; 下面我们使用Object.defineProperty()分别演示数据属性和访问器属性; 注意:数据属性和访问器属性不能同时设置,也就是数据属性writable...定义多个属性Object.defineProperties() 在一个对象上同时定义多个属性可能性是非常大。...读取属性特性Object.getOwnPropertyDescriptor() Object.getOwnPropertyDescriptor()方法接收两个参数:属性所在对象和要取得其描述符属性

2.3K20

面向对象中Object常用属性总结

学完Object属性,自己总结一些常用是Object常用属性Object.prototype:属性表示Object原型对象。...属性Object.prototype.constructor:特定函数,用户创建一个对象原型。 Object.prototype....描述:如果目标对象中属性 有相同键,则属性将被源中属性覆盖,后来属性将类似地覆盖早先属性Object.create():方法会使用指定原型对象及其属性去创建一个新对象。...语法:Object.freeze(obj) obj:将要被冻结对象 Object.getOwnPropertyDescriptor():方法返回指定对象上有一个自有属性对应属性描述符(自有属性是直接...+ Object.getOwnPropertyNames():方法返回一个由指定对象所有自身属性名(包括不可枚举属性但不包括Symbo值作为名称属性)组成数组。

88820

js对象属性

(let p in zhangsan){ console.log(zhangsan.hasOwnProperty(p),`${p}:${zhangsan[p]}`) } 参考代码 codepen关于js...方法 内容 备注 for in 可枚举,自身以及继承属性 对象以及继承,可枚举,不含 Symbol 属性 Object.keys(obj) 返回一个数组,包括对象自身(不含继承)所有可枚举属性键名...对象自身可枚举,不含 Symbol 属性 Object.getOwnPropertyNames(obj) 返回一个数组,包含对象自身所有属性(不含 Symbol 属性,但是包括不可枚举属性键名 对象自身...,包括不可枚举属性 Object.getOwnPropertySymbols(obj) 返回一个数组,包含对象自身所有 Symbol 属性键名 对象自身,symbol Reflect.ownKeys...参考源码:vue框架使用get,set源码地址 Object.defineProperty(obj, key, { enumerable: true, configurable: true

15.6K10

js nextSibling属性和previousSibling属性

1:nextSibling属性属性表示当前节点下一个节点(其后节点与当前节点同属一个级别);如果其后没有与其同级节点,则返回null。...需要特别注意是:该属性在不同浏览器中执行结果并不都相同,见下面例示: 先来看一个例子: <input id=“a4” type=“button” οnclick...opera和safari对nextSibling处理方式与FF一致 2:previousSibling属性属性与nextSibling属性作用正好相反。...3:通过nextSibling或者 previousSibling所获得HTML标签元素对象属性问题 一般先通过nextSibling.nodeName来获知其标签名,或者通过nextSibling.nodeType...如果该nextSibling.nodeName = #text,则通过nextSibling.nodeValue来获知其文本值;否则,可以通过nextSibling.innerHTML等其他常用标签元素属性来获取其属性

6.5K30

使用 object-fit 属性完美过渡图片

object-fit 属性指定元素内容应该如何去适应指定容器高度与宽度, 一般用于 img 和 video 标签,一般可以对这些元素进行保留原始比例剪切、缩放或者直接进行拉伸等在我们工作中,经常会遇到附件上传...,然后展示多张图片,这些图片尺寸大小不一,如果不进行样式统一设置,看起来会比较不美观,这时我们可以使用 object-fit 属性对其设置。...1、 先让我们看一下 object-fit 属性值: 2、 我们新建一个 html 文件,引入几张高度不一图片: CSS属性 object-fit...: cover 样式: 此时图片能保持原有尺寸比例 5、 如果想改变图片显示位置,我们可以对其设置 object-position: right top 属性: 6、 我们还可以使用 object-position...属性一般与 object-fit一起使用,用来设置元素位置,两者结合可以实现很多图片动画效果,有兴趣可以自行研究一下。

15110

使用 Object.defineProperty 为对象定义属性

Object.defineProperty() 定义以及使用 Object.defineProperty() 方法会直接在一个对象上定义一个新属性,或者修改一个已经存在属性, 并返回这个对象。...因此 Object.defineProperty 方法是对属性更加精确定义。...当且仅当该属性 enumerable 为 true 时,该属性才能够出现在对象枚举属性中(for…in 或者 Object.keys) get: 默认为 undefined。...Object.freeze(obj) Object.freeze() 方法可以冻结一个对象,冻结指的是不能向这个对象添加新属性,不能修改其已有属性值,不能删除已有属性,以及不能修改该对象已有属性可枚举性...也就是说,这个对象永远是不可变。该方法返回被冻结对象。 最后 了解了 Object.defineProperty 用法,接下来就是写一个自己 Vue.js 了。敬请期待。

90510
领券