属性描述符是ES5中的一个重要的概念。它可以对对象做一些特定的高级操作,今天我们就学习一下ES5中的属性描述符。...ES5中的属性描述符是由Object类的一个静态方法defineProperty来设置的,该方法接收三个参数,分别是:属性操作的对象、属性名和一个属性描述符的对象。...属性描述符是由第三个参数来决定属性可以做哪些操作,这个对象可以设置以下的值: 描述符的值 描述 默认值 value 值 undefined writable 是否可写 true configurable...如果多次设置同一个属性的属性描述符那么后面的会覆盖前面的。...批量设置多个属性描述符的时候,可以使用Object.defineProperties方法。
属性描述符是 ECMAScript 5 新增的语法,它其实就是一个内部对象,用来描述对象的属性的特性。属性描述符的结构在 JavaScript 中,对象的属性描述符用于描述和定义对象属性的特性。...操作属性描述符属性描述符是一个内部对象,无法直接读写,可以通过下面几个函数进行操作。Object.getOwnPropertyDescriptor( ):可以读出指定对象私有属性的属性描述符。...Object.defineProperty( ):通过定义属性描述符来定义或修改一个属性,然后返回修改后的描述符。Object.defineProperties( ):可以同时定义多个属性描述符。...修改属性描述符的 set 函数,重设检测条件,允许非数值型数字赋值。...通过使用这些描述符,我们可以灵活地控制和定义对象的属性行为,例如限制某些属性只读、隐藏某些不需要枚举的属性等。
ES5之后,所有的属性都存在属性描述符这个属性。...获取属性描述符属性的方法是: Object.getOwnPropertyDescriptor 以下面的代码为例: var object = { a: 2 } Object.getOwnPropertyDescriptor...); //返回 {value: 2, writable: true, enumerable: true, configurable: true} 该方法返回的是一个对象,该对象除了包含value为2的属性外...,还包含了属性的三个特性。...writable (是否可修改属性的值) enumerable (是否出现在对象的属性枚举中) configurable (是否可配置,属性设置为false之后,该属性值为不可逆的,也就是说不能再修改为
简介 JS的对象是一组无序属性的集合。那么对于这组无序属性来说,拥有哪些特性呢?ECMAScrip5中定义了属性的这些特性,但这些特性是为了实现JS引擎用的,在JS中无法直接来访问它们。...该方法接受三个参数:属性所在对象,属性名字和一个描述符对象。 属性所在对象,属性名字很好理解。那么属性描述符对象呢?...属性描述符详解 4.1 数据属性描述符对象 4.1.1 属性值value 对于数据属性,我们通过value来定义和获取其属性值。...能够操纵属性描述符的方法 7.1 为目标对象设置单个属性 设置单个属性可以使用Object.defineProperty()方法,要注意的是,对于同一个属性,不可以同时在描述符中指定属于数据描述符的value..._doubleA); // 2 参考 BOOK-《JavaScript高级程序设计(第3版)》第6章 BOOK-《你不知道的JavaScript》 第2部分 JS属性特性(属性描述符) ECMAScript
描述符示例:验证属性 2. 自动获取储存属性的名称 3. 继承改进 4....描述符示例:验证属性 描述符是对多个属性 运用 相同存取逻辑的一种方式 描述符是实现了 特定协议 的类,这个协议包括 __get__、__set__ 和 __delete__ 方法 property...——管理 数据属性 这种描述符也叫覆盖型描述符,因为描述符的 __set__ 方法使用托管实例中的同名属性覆盖(即插手接管)了要设置的属性 4....覆盖型与非覆盖型描述符对比 通过实例读取属性时, 通常返回的是实例中定义的属性; 但是,如果实例中没有指定的属性, 那么会获取类属性。...描述符用法建议 创建只读属性最简单的方式是 使用特性 property 使用 描述符类 实现只读属性,要记住,__get__ 和 __set__ 两个方法必须都定义,否则,实例的同名属性会遮盖描述符 用于
> beanClass) 该构造函数使用简单属性的名称,以及读取和写入属性的方法名称 public PropertyDescriptor(String propertyName, Class beanClass, String readMethodName, String writeMethodName) 此构造函数使用简单属性的名称,以及用于读取和写入属性的Method对象。...UserInfo.class; PropertyDescriptor p = new PropertyDescriptor("name", clazz); System.out.println("显示属性描述类...:" + p); } 显示属性描述类: java.beans.PropertyDescriptor[ name=name; propertyType=class java.lang.String...UserInfo.class; PropertyDescriptor p = new PropertyDescriptor("name", clazz); System.out.println("显示属性描述类
本文首发于本博客 猫叔的博客,转载请申明出处 前言 感谢GY丶L粉丝的提问:属性描述器PropertyDescriptor是干嘛用的?...本来我也没有仔细了解过描述符这一块的知识,不过粉丝问了,我就抽周末的时间看看,顺便学习一下,粉丝问的刚好是PropertyDescriptor这个属性描述符,我看了下源码。.... */ public class PropertyDescriptor extends FeatureDescriptor { //... } emmmm,假装自己英语能厉害的说,属性描述符描述了一个属性...PropertyDescriptor 那么我们大致知道了FeatureDescriptor,接下来就可以来深入了解看看这个属性描述符PropertyDescriptor。...一些使用方式 其实在我上面写一些构造函数的时候,我想大家应该已经感受到与反射相关了,起码我感觉上是这样的,所以我一开始想到这样的案例形式,通过反射与这个属性描述类去赋予我的类。
可枚举属性 对象属性可枚举,表示该属性的值不可修改,可认为该属性是常量。 如何定义不可枚举的属性?...使用Object.keys(obj)可以获取对象obj自身所包含的所有可枚举属性。...Object.getOwnPropertyNames(obj) ;//获得对象上所有的“实例属性” 判断对象是否拥有实例属性 obj.hasOwnProperty(‘id’); //只要该对象obj...拥有属性id, 无论id是否可枚举,都返回true for(var i in obj){ } // 表示访问对象所有可枚举的属性,包括可枚举的实例属性和可枚举的原型对象的属性 “name” in...obj // 通过对象能够访问给定属性名时返回true, 无论该属性存在于实例中还是原型对象中
前言 相信对于对象属性大家都或多或少的知道一些,那么本文从属性说开去,看看大家对属性的了解是否有遗漏的部分。...官方对属性分为两种,一种是数据属性,另一种访问器属性。...构造函数得到的属性以及基本属性赋值 //正常的构造函数以及对象属性赋值,call .apply构造函数继承方式的属性都可以正常获取,并且属于对象自有属性 let Animal = function ()...(let p in zhangsan){ console.log(zhangsan.hasOwnProperty(p),`${p}:${zhangsan[p]}`) } 参考代码 codepen关于js...对象属性的案例 还什么方法可以拿到属性 没错,我们一般情况下使用for,in循环获取属性,但有些属性我们也希望得到。
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等其他常用标签元素属性来获取其属性
JavaScript属性描述对象的操作 1、属性分为数据属性、访问器属性。访问器属性不包含数据值,通常包含getter、setter函数。...2、采用内部特性来描述属性的特征,属性描述符是ES5开始支持的语法。...false, enumerable: true, configurable: false, get: undefined, set: undefined } 以上就是JavaScript属性描述对象的操作
object.publicMethod = function(){ privateVariable++ return privateFunction() } return object; //特权/公有方法和属性
方式一:在定义对象时,直接添加属性和方法 function Person(name,age) { this.name = name; this.age = age; this.say = function...() { alert(name + ':::' + age); } } var person = new Person('张三', 24); person.say(); 方式二:通过”对象.属性名...); person.name = '张三'; person.say = function() {alert(this.name)}; person.say(); 方式三:通过prototype(原型)属性添加
.*" }; 如果你想要删除regex属性,使得新的对象成为下面这样: let myObject = { "ircEvent": "PRIVMSG", "method": "newURI..." }; 我们该如何删除对象的regex属性呢?...以上就解决了js如何删除运算符。
属性决定JS中对象的状态,本文章主要分析这些属性是如何工作的。 JS几种不同的属性 JS有三种不同的属性:数据属性,访问器属性和内部属性。...如果设为false,将阻止某些操作改写该属性,比如无法删除该属性,也不得改变该属性的属性描述对象(value属性除外)。也就是说,configurable属性控制了属性描述对象的可写性。 3....属性描述 JavaScript 提供了一个内部数据结构,用来描述对象的属性,控制它的行为,比如该属性是否可写、可遍历等等。这个内部数据结构称为“属性描述对象”(attributes object)。...每个属性都有自己对应的属性描述对象,保存该属性的一些元信息。下面是值为123属性描述对象的一个例子。...,属性描述对象如下所示: { get: function () { return 123 }, enumerable: true, configurable: false } 3.1 使用属性描述符的函数
} else { return num * arguments.callee(num - 1);//函数内部属性...> () { return 0; }; alert(trueFactorial(5));//120 使用callee属性...可以继续使用递归 否则返回0 alert(factorial(5)); //0 2.Length:表示函数希望接收的命名参数的个数 3.prototype:在创建自定义引用类型以及实现继承时,该属性的作用极为重要...,该属性不可枚举,因此使用for-in 无法发现 方法: 1.apply()和call() 用途:在特定的作用域中调用函数,等于设置函数体内this对象的值 <span style="color:
1.删除属性 delete运算符可以删除对象的属性 delete person.age //即person不再有属性age delete person['age'] //或者这样 delete只是断开属性和宿主对象的联系...,而不会去操作属性中的属性 看到delete a.p之后b.x仍然为1 var a = {p:{x:1}}; var b = a.p; console.log(a.p.x); //1 delete a.p...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){...obj.hasOwnProperty("y")); //false console.log(obj.hasOwnProperty("toString")); //false 因为obj继承了这个方法,但不是它自己的 只有检测到是自由属性并是可枚举的属性时
(实例属性和描述符实例同名)!...如果某个公开属性是由描述符管理的,这个公开属性就是托管属性,否则就是一般的属性。但托管属性并不是指与之同名的用作类属性的描述符实例。...或者说,与self.storage_name同名的属性就是储存属性。这里也体现了“描述符”为什么叫“描述符”:把一个属性“描述”成另一个属性。...可以分为以下三种情况(再次提醒,描述符是类属性): 如果描述符实现了__get__和__set__方法,描述符会覆盖同名实例属性,即属性的存取值过程都会被描述符接管。...在赋值过后,obj中有了实例属性non_over,并且它覆盖了描述符,读值过程没有被接管。删除了实例属性后,描述符不再被覆盖。非覆盖型描述符可以实现缓存。 4.
这时候就要召唤Python的描述符机制了,他的存在是python开发者能够复用与属性相关的逻辑。 描述符协议 Python描述符协议是一种再模型中引用属性时将要发生事件的方法。...描述符的原理 上面进行了基本的描述符创建和使用效果,那么描述符是如何工作的才能让我们以这种方式操作属性呢? 一句话总结就是通过将属性访问进行了转译。...描述符触发 当我们进行属性访问时便会触发描述符(如果这个属性具有描述符定义的时候),当我们对对象obj的属性d进行访问时候,obj.d,描述符的触发过程大致:先在对象obj的字典中寻找d,如果d是个含有...官方文档中对具体的触发细节进行了更详细的描述,具体的触发又分为我们访问的是类属性还是实例属性: 1....我们创建了两个学生实例,但是身高属性却是同一个对象,这是因为描述符是类属性,因此每个实例中进行访问的时候都是访问的类属性的引用。
领取专属 10元无门槛券
手把手带您无忧上云