- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在下面的示例代码中,我想检测属性(“cv”)是否进一步链接到其他描述符。当处理数据描述符时,这会陷入一个兔子洞,并且没有尽头,因为 JS 不断返回数据描述符。如果链深处存在访问器,我们可以通过测试是否定义了访问器函数来检测它。
目标是使用值属性的描述符复制描述符的值属性,将其保存在某处并使用访问器描述符稍后访问保存的值。但是,这需要在不无意中实际调用任何深层访问器的情况下完成(这最终会返回一个最终会过时的计算值)。以下内容将不起作用
var newDescriptor = {
value : oldDescriptor.value
}
以下内容
var newDescriptor = {}
Object.defineProperty(newDescriptor, value, Object.getOwnPropertyDescriptor(oldDescriptor, 'value'));
可能可以工作,但在一次又一次调用时最终会堆积不必要的描述符链,这最终可能会耗尽内存。但此解决方案还需要检测是否已经为描述符设置了这样的链,并可能通过拾取叶级数据描述符来减少它们。这给我们带来了数据描述符兔子洞!
真正的用例是将现有数据描述符转换为访问器描述符,而表观数据描述符可能并非如此并且已经链接了深层访问器。我可能缺少其他更好的方法来解决这个问题。
代码示例
var ob = {cv : 5};
console.log(" ob.cv : " + ob.cv ); // Returns 5
var cvd1 = Object.getOwnPropertyDescriptor(ob, 'cv');
console.dir( cvd1 );
var cvd2 = Object.getOwnPropertyDescriptor(cvd1, 'value');
console.dir( cvd2 );
var cvd3 = Object.getOwnPropertyDescriptor(cvd2, 'value');
console.dir( cvd3 );
// Deepest chained accessor descriptor
var deepAccessorDescriptor = {};
Object.defineProperty(deepAccessorDescriptor, 'value', {
get : function() { return 74 ; }
} );
// Chained data descriptor
var chainedDataDescriptor = {};
Object.defineProperty(chainedDataDescriptor, 'value', deepAccessorDescriptor );
Object.defineProperty(ob, 'cv', chainedDataDescriptor);
console.log(" ob.cv : " + ob.cv ); // Returns 74 from deepAccessorDescriptor
最佳答案
描述符不能被链接。就这么简单。
当您调用Object.defineProperty
时,它不会存储您传递的描述符对象 - 它只是查看它并将相关内容存储在属性的属性中。
当您调用Object.getOwnPropertyDescriptor
时,它不会访问以前存储的对象。它检查属性的属性,并使用纯数据属性创建一个新对象来描述属性。
var deepDescriptor = {};
Object.defineProperty(deepDescriptor, 'value', {
get() {
console.log("evaluated");
return 74;
}
});
console.log("descriptor created");
var ob = {};
Object.defineProperty(ob, 'cv', deepDescriptor);
console.log("property defined");
console.log("ob.cv", ob.cv);
您可以看到 deepDescriptor.value
getter 是在 Object.defineProperty(…, deepDescriptor)
调用期间而不是在 ob.cv
访问。
关于javascript - 不评估访问器检测 Object.defineProperty 是否具有链式数据描述符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49988007/
我正在寻找这两种方法之间的主要区别。 一些网站提到了可读性问题,但我的担忧主要是与性能相关。看起来像defineProperty()更快,但我找不到原因。 var FOR_TIME = 10000;
我正在做一个 JavaScript 项目,只是想知道为什么对象实例不继承 defineProperty() 和其他方法,而不必调用父类(super class)(superobject?) 对象方法。
在 React 配置中使用 eslint 在使用 Object.defineProperty 时出现错误。错误说: Avoid using Object.defineProperty, instead
Object.defineProperty函数会直接在一个对象上定义一个新的属性,或者修改一个对象的现有属性,并返回此对象。 一、简单使用 const obj = {} Object.defineP
我使用React、Webpack、Babel构建项目,希望它在IE8中运行,存在IE8不支持Object.defineProperty的问题。 我没有使用这个功能,但是 npm 包可以做到这一点,比如
我想构建一个检测对象更改的代理: 定义了新属性。 现有属性已更改。 代码示例 1 - defineProperty const me = { name: "Matt" } const proxy
下面我尝试使用defineProperties函数定义对象的属性,但是当我打印此脚本中的最后一行时,我得到了意外的结果。我希望在控制台上记录 2005 年,但我不断收到 2004 年。这同样适用于其他
假设在我的模块中我有这样的东西: Object.defineProperty(Array.prototype, 'sayHello', {get: functio
我最近为 node.js 创建了自己的模块,用于 koa 模块。它是一个类似 koa-i18n 的翻译模块。我研究了其他 koa 模块以了解函数/属性如何应用于 koa 上下文/请求,其中一些使用 O
这个问题已经有答案了: JavaScript closure inside loops – simple practical example (45 个回答) 已关闭 6 年前。 在我的代码中我有一个
我正在尝试使用 defineProperty 使属性不出现在 for...in 循环中,但它不起作用。这个代码正确吗? function Item() { this.enumerable =
我正在尝试从 ABAP 执行 JS 代码,但出现以下错误: Object.defineProperty is not a function. 我的代码: Object.defineProperty(o
所以我一直在我的主要 javascript 启动文件中使用一堆这些,我需要其中的 20-30 个。有没有办法可以从不同的文件中导出这些文件,以便清理我的主文件? Reflect.definePrope
询问 Object.defineProperty 如下所示: function testComponent(){ var testProperty; Object.defineProp
我最近重组了我的 Three.js 项目,我开始遇到一个问题,每个对象似乎都是用完全相同的几何形状和 Material 渲染的。我在调试器中跟踪了这个构造函数的问题: function Geometr
var funcSetter = { defineProperty: function(target, prop, descriptor) { if (prop) {
我是 js 世界的新手,发现 jquery 将许多属性声明为方法,这让我非常不舒服。例如 $("#foo").parent() 我认为应该是属性。 我知道js也可以定义属性,所以我想尝试将这些方法重新
前言: Feel free to skip to the actual question below, if you find the'backstory' here unnecessary. But
我正在尝试创建自己的类对象并使用它来存储应用程序的各种数据类型,这在使用已发布属性时一切正常,我可以将它们流式传输到磁盘并毫无问题地返回。但我还需要流式传输一些动态整数类型数组。
我试图覆盖我应用程序中所有 iframe 的 src 属性,因此无论 HTML 的值是什么,它们的 src 属性总是设置为“redirect.html”标签为其定义。到目前为止,我提出了以下建议,但它
我是一名优秀的程序员,十分优秀!