- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
很久以前,我一直愿意让原生数组和常规对象之间的界限完全模糊,不仅扩展对象具有与数组在 ES5 中获得的相同功能,而且还与我自定义的方法包捆绑在一起。
一些聪明人考虑了这些范式变化。就像 Angus Croll 在文章中提到的 javascript-object-keys-finally :
"Moreover as the line between Arrays and regular Objects blurs (aided by custom getters and setters) we’re likely to see a growth in generic “array-like” objects which enjoy the best of both worlds – non-numeric identifiers and access to the rich API set defined by Array.prototype. EcmaScript 5 has apparently pre-empted this trend by introducing the generic method, defined by one type but useable by any."
一路上,他在文章中编码了一些东西: extending-objects-with-javascript-getters
function extendAsArray(obj) {
if (obj.length === undefined || obj.__lookupGetter__('length')) {
var index = 0;
for (var prop in obj) {
if(!obj.__lookupGetter__(prop)) {
(function(thisIndex, thisProp) {
obj.__defineGetter__(thisIndex, function() {return obj[thisProp]});
})(index, prop)
index++;
}
};
obj.__defineGetter__("length", function() {return index});
}
return obj;
}
var myObj = {
left:50,
top:20,
width:10,
height:10
}
extendAsArray(myObj);
[].map.call(myObj,function(s){return s+' px'}).join(', ');
//"50px ,20px ,10px, 10px"
这种方法对我来说特别有趣。然而,它似乎也存在一些严重的问题!
如何使用几个新属性扩展原始 myObj 模型?我们是否应该在每次属性更改时运行 extendAsArray
以更新它与 length
属性有关?
当属性发生变化时,相关的不仅仅是length
属性;数组索引也应该更新,因为类似数组的属性请求肯定是未定义的。所以当
console.log(myObj.length) -> 4
myObj.zAxis=0
然后
console.log(myObj[4]) // -> undefined!
console.log(myObj.length) // -> 4!
我已经相应地修改了 Angus 的代码,因此它支持根据要求自动更新 length
属性:
function extendAsArray(obj) {
var index = 0;
for(var prop in obj){
if(!obj.__lookupGetter__(prop)){
(function(thisIndex, thisProp){
Object.defineProperty(obj, thisIndex, {
get: function(){return obj[thisProp]}
, enumerable: true
, configurable: true
, writeable: true
});
})(index, prop)
index++;
}
}
if(!obj.__lookupGetter__('length')){
Object.defineProperty(obj, 'length', {
get: function(){
return extendAsArray(obj);
}
, configurable: true
, writeable: true
});
return obj;
}
else{
return index;
}
}
问题是:当更改、添加或删除属性时,我们如何更新对象的数组索引及其 length
属性?
我应该使用 Object.watch
吗?
还有一个 Unresolved 问题:如何干扰我自己的未填充实用程序库,以一致的方式为对象制作它?
我对这两种类型使用相同的代码库:z.Object({}).mapEvery
与 z.Object([]).mapEvery
的作用相同>/p>
请避免提及 JQuery 和 Underscore。对于这两种类型,我都有一个全面的、自定义的方法列表,我愿意使用我的未填充方法可能完成的标准,我不愿意重构它!
最佳答案
我想这是你的问题:
how do we updating the object's array indices together with its length property when a property is changed, added or removed?
您创建方法来执行此操作,因此您基本上模仿了 Object internal methods .我不认为你可以用 getter 和 setter 来做到这一点,但我对此可能是错的。
剩下的更多的是评论而不是答案。
I have long ago been willing to get the line between native Arrays and regular Objects totally blurred
这条线已经完全模糊了。数组是对象,唯一使它们与众不同的是它们特殊的长度属性。
EcmaScript 5 has apparently pre-empted this trend by introducing the generic method,
ES5 没有引入泛型方法,它们至少从第 3 版开始就已经存在了。
defined by one type but useable by any
一点也不,事实上 ES5 限制更多。在第 3 版中,call
和 apply
使用 Object(*thisArg*)
将 thisArg 强制为一个对象,或者如果未传递任何内容,则替换全局对象。在 ES5 中不是这样,thisArg 未修改。
将数组用作对象的限制与约定有关,与语言本身无关。大多数开发人员在何时应该使用对象或数组之间看到了明显的区别。在极少数情况下,您确实需要像使用对象一样使用数组,但毫无疑问它们存在。 jQuery 是对象利用数组属性的示例,例如选择器收集的元素被添加为数字属性,并且有一个长度属性,它是元素的数量。这样通用数组方法就可以应用于 jQuery 对象(顺便说一下,所有这些都在第 3 版中)。
Object.watch
方法在 JavaScrpit™ 中,它不是 ES5 的一部分,因此请谨慎使用。
创建自己版本的内置对象的一个主要问题是,您可能最终将每个内置方法包装在 native 方法中(就像 jQuery 几乎包装每个 DOM 方法一样)并开始设置 getter 和 setter在每个属性上,或者以函数调用结束以替换属性访问(例如 jQuery 的 val
、attr
和 prop
方法)。如果性能很重要,则相当乏味且缓慢。
哦,抱歉,我提到了 jQuery……:-(
设计一个库或框架以充分利用该语言的特性似乎更明智,而不是试图强制它做它做不好或 native 做不到的事情.
但尝试满分。 :-)
关于javascript - 扩展常规对象以支持 ES5 数组功能的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15373344/
我正在尝试创建一个包含 int[][] 项的数组 即 int version0Indexes[][4] = { {1,2,3,4}, {5,6,7,8} }; int version1Indexes[
我有一个整数数组: private int array[]; 如果我还有一个名为 add 的方法,那么以下有什么区别: public void add(int value) { array[va
当您尝试在 JavaScript 中将一个数组添加到另一个数组时,它会将其转换为一个字符串。通常,当以另一种语言执行此操作时,列表会合并。 JavaScript [1, 2] + [3, 4] = "
根据我正在阅读的教程,如果您想创建一个包含 5 列和 3 行的表格来表示这样的数据... 45 4 34 99 56 3 23 99 43 2 1 1 0 43 67 ...它说你可以使用下
我通常使用 python 编写脚本/程序,但最近开始使用 JavaScript 进行编程,并且在使用数组时遇到了一些问题。 在 python 中,当我创建一个数组并使用 for x in y 时,我得
我有一个这样的数组: temp = [ 'data1', ['data1_a','data1_b'], ['data2_a','data2_b','data2_c'] ]; // 我想使用 toStr
rent_property (table name) id fullName propertyName 1 A House Name1 2 B
这个问题在这里已经有了答案: 关闭13年前。 Possible Duplicate: In C arrays why is this true? a[5] == 5[a] array[index] 和
使用 Excel 2013。经过多年的寻找和适应,我的第一篇文章。 我正在尝试将当前 App 用户(即“John Smith”)与他的电子邮件地址“jsmith@work.com”进行匹配。 使用两个
当仅在一个边距上操作时,apply 似乎不会重新组装 3D 数组。考虑: arr 1),但对我来说仍然很奇怪,如果一个函数返回一个具有尺寸的对象,那么它们基本上会被忽略。 最佳答案 这是一个不太理
我有一个包含 GPS 坐标的 MySQL 数据库。这是我检索坐标的部分 PHP 代码; $sql = "SELECT lat, lon FROM gps_data"; $stmt=$db->query
我需要找到一种方法来执行这个操作,我有一个形状数组 [批量大小, 150, 1] 代表 batch_size 整数序列,每个序列有 150 个元素长,但在每个序列中都有很多添加的零,以使所有序列具有相
我必须通过 url 中的 json 获取文本。 层次结构如下: 对象>数组>对象>数组>对象。 我想用这段代码获取文本。但是我收到错误 :org.json.JSONException: No valu
enter code here- (void)viewDidLoad { NSMutableArray *imageViewArray= [[NSMutableArray alloc] init];
知道如何对二维字符串数组执行修剪操作,例如使用 Java 流 API 进行 3x3 并将其收集回相同维度的 3x3 数组? 重点是避免使用显式的 for 循环。 当前的解决方案只是简单地执行一个 fo
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我有来自 ASP.NET Web 服务的以下 XML 输出: 1710 1711 1712 1713
如果我有一个对象todo作为您状态的一部分,并且该对象包含数组列表,则列表内部有对象,在这些对象内部还有另一个数组listItems。如何更新数组 listItems 中 id 为“poi098”的对
我想将最大长度为 8 的 bool 数组打包成一个字节,通过网络发送它,然后将其解压回 bool 数组。已经在这里尝试了一些解决方案,但没有用。我正在使用单声道。 我制作了 BitArray,然后尝试
我们的数据库中有这个字段指示一周中的每一天的真/假标志,如下所示:'1111110' 我需要将此值转换为 boolean 数组。 为此,我编写了以下代码: char[] freqs = weekday
我是一名优秀的程序员,十分优秀!