标签:typescript name descriptor writable 访问 test 装饰 string 属性
我们知道,在js中类中(Object)中的属性有4个描述起行为的特性:
Configurable:表示能否通过delete删除属性从而重新定义属性;
Enumerable:表示能否通过for-in循环返回属性
writable:表示能否修改属性的值
Value:包含这个属性的数据值(个人认为其作用就是赋值)
以上四个属性在不显示调用Object.defineProperty()的时候,前三个默认值都为true,而value为你自己设定的值,如果不设定的话则为undefined。
而其中最特殊的则是configurable,根据《javascript高级程序设计(第三版)》所说:一旦把该属性定义为false之后,那么除了writable之外,其他所有的属性都无法再修改。
/** * 访问器装饰器的参数 * @param target 类的原型对象 * @param key 属性的名称(被装饰的属性) * @param descriptor 描述符 */ function visitDecorator(target: any, key: string, descriptor: PropertyDescriptor) { descriptor.writable = false; } class Test{ private name: string; // 访问器:private、 public、 protect constructor(name: string) { this.name = name; } get getName() { return this.name } @visitDecorator set setName(name: string) { this.name = name; } } const test = new Test('张三'); console.log(test.getName); test.setName = '李四'; console.log(test.getName); // 访问器装饰器将 writable 为 false 也是会报错的,因为这不能重写 // 错误:TypeError: Invalid property descriptor. Cannot both specify accessors and a value or writable attribute, #<Object>
标签:typescript,name,descriptor,writable,访问,test,装饰,string,属性 来源: https://www.cnblogs.com/wuchen-wanou/p/14915709.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。