Zol*_*aKt 5 javascript arrays jquery json getjson
有没有办法让$ .getJSON返回变量数组?
我知道它的异步和超出范围,但我会在ajax回调中使用它,我只需要先获取所有值并检查它们与另一个数组.
就像是:
$.getJSON('itemManager.php?a=getItems', function(data){
// itemArray = new Array(data);
// idsArray = new Array(data.id);
for (var i in someOtherArray){
if($.inArray(i, idsArray) == -1){
// do something...
// get jason variable by id?
// itemArray[i].someVariable
}
}
}
Run Code Online (Sandbox Code Playgroud)
编辑: JSON结构
[{"id":"786","user_id":"1","seller_id":"2","address_id":"1","time":1299852115,"publicComment":null,"personalComment":null},
{"id":"787","user_id":"1","seller_id":"2","address_id":"1","time":1299852115,"publicComment":null,"personalComment":null},
{"id":"785","user_id":"1","seller_id":"2","address_id":"1","time":1299852114,"publicComment":null,"personalComment":null},
{"id":"784","user_id":"1","seller_id":"2","address_id":"1","time":1299852113,"publicComment":null,"personalComment":null},
{"id":"783","user_id":"1","seller_id":"2","address_id":"1","time":1299852111,"publicComment":null,"personalComment":null}]
Run Code Online (Sandbox Code Playgroud)
这基本上就是这个想法.
我猜这里有各种解决方案,但我正在寻找代码最少的东西.
根据给定的信息,没有捷径可以测试 ID 的存在。你真的必须遍历所有内容。但是,您可以通过创建映射来改进一点id => object:
$.getJSON('itemManager.php?a=getItems', function(data){
var items = {};
for(var i = data.length; i--; ) {
items[data[i].id] = data[i];
}
for (var j = someOtherArray.length; j--; ){
var item = items[someOtherArray[j]];
if(item){
// do something with `item`
}
}
}
Run Code Online (Sandbox Code Playgroud)
如果您已经在服务器上创建了这个结构,那就更好了,那么它将是:
$.getJSON('itemManager.php?a=getItems', function(data){
for (var j = someOtherArray.length; j--; ){
var item = data[someOtherArray[j]];
if(item){
// do something with `item`
}
}
}
Run Code Online (Sandbox Code Playgroud)
您还应该考虑哪些数组将包含更多元素,data或者someOtherArray调整数据结构,以便仅循环较小的数组。
更新:
要使用 PHP 在服务器上创建适当的结构,您必须创建一个关联数组。
因此,在将对象添加到数组时,您不应该这样做
$items[] = $obj;
Run Code Online (Sandbox Code Playgroud)
但
$items[$obj->id] = $obj; // or $obj['id'] if you have an array
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
13679 次 |
| 最近记录: |