Jquery中有对象类型变量:
var obj = *{"1234" : "xx", "4321" : "yy", "5555" : "hh", "2321" : "aa" };*
假设我想要删除从属性名称"5555"到对象末尾的每个属性(这意味着我想要delete obj['5555']
和delete obj['2321']
)。我对最聪明的方式感兴趣,通过循环来做到这一点。
在数组中,我会使用splice(2, arr.length)
,但我很困惑。
不能保证对象属性的顺序。在我的控制台中粘贴示例对象时,我看到了以下内容:
> obj = {"1234" : "xx", "4321" : "yy", "5555" : "hh", "2321" : "aa" }
Object {1234: "xx", 2321: "aa", 4321: "yy", 5555: "hh"}
正如您所看到的,chrome按照升序排列属性,就像数组一样。谁知道呢,但也许IE不这么做。。。也许有些晦涩难懂的浏览器会按降序排列属性。。。没有办法知道实际物体会是什么样子,所以也许要重新思考一下
如果你的所有属性本质上都是数字的,那么使用数组并没有错,在JS中,Array
原型只是一个增强的Object
:
obj = [];
obj[1234] = 'xx';
obj[2321] = 'aa';
obj[5555] = 'hh';
数字索引在内部被强制为字符串(因为Array是对象),所以JS不会为您创建无尽的空索引,它解析obj[200]
就像解析objectLiteral.undefinedProperty
一样:先扫描实例,然后解析prototypechain。如果找不到请求的属性,则返回undefined。
它们是在你前进的过程中添加的,但这里有两种方法:
//Assume simpel object (non-nested)
var newObj = JSON.parse(JSON.stringify(obj).replace(/{|,s*"5{4}"s*:.+$/,'}'));
我认为,这是最简单的方法,但不太可靠。最"久经考验"的方法是:
var unset = false;
for (var prop in obj)
{
if (obj.hasOwnProperty(prop))
{
unset = unset || !!(prop === '5555');
if (unset === true)
{
delete(obj[prop]);
}
}
}
最后一种方法创建一个数组,其中包含所有键,您可以通过这种方式对其进行迭代并删除属性。这里只是为了完整性:不过,我不会使用它,因为它需要支持ES5规范的浏览器(遗憾的是,并非所有浏览器都支持),而且与上面的代码相比没有真正的优势:
var keys = Object.keys(obj).sort(),//call sort to assure ascending order
toDelete = keys.splice(keys.indexOf('5555'), keys.length).sort();
for(var i=0;i<toDelete.length;i++)
{
delete obj[toDelete[i]];
}
将要搜索的obj和要查找的值推送到一个函数中,该函数返回一个新对象,该对象仅具有您指定的值。
function returnNewobj(obj, value) {
var newObj = {};
for (var prop in obj) {
if (obj.hasOwnProperty(prop)) {
if (prop === value) return newObj;
newObj[prop] = obj[prop];
}
}
return newObj;
}
编辑:可能没有必要,但为了安全起见,我添加了hasOwnProperty行。
第2版:值得指出的是,新属性是按字母数字顺序添加到对象中的,而不是像元素添加到数组那样添加到对象的末尾。所以不要被这件事所困扰。
我建议您获取要从中开始删除元素的元素的索引,然后循环抛出删除具有更高索引的元素的对象。
您可能想要创建一个函数,使其更类似于您喜欢的splice
i。
找到要查找的元素,并将该特定元素以及之后的任何元素设置为null
。
删除属性名称非常棘手,但属性值可能为null或未定义,但删除属性很困难,但你可以做一件事,可以在新对象中复制所需的属性,这是一种变通方法,尽管这里有一个我经常在这种情况下使用的示例
objCopyTo[strToPropertyName] = objCopyFrom[strPropertyName];
这是小提琴