我在网上找到的这段代码运行良好,这正是我想要实现的目标:
$(document).ready(function(){
var arrData = [ "j", "Q", "u", "e","r","y" ];
alert(jQuery.inArray("Q", arrData));
});
但是,我有一个来自php / mysql循环的数组,我输出并保存如下:
$query = mysql_query("SELECT * FROM geo_orter");
while(($row = mysql_fetch_assoc($query))){
$i = $row['ort_id'];
$result[$i] = $row['ortnamn'];
};
$allaOrterjson=json_encode($result);
然后我继续这样做,这有效:
var allaOrter=<?php echo $allaOrterjson ?>;
document.write(allaOrter[0] + allaOrter[1] + allaOrter[2]);
并给我
undefinedAborremålaAbbjörnahall
问题在于:
我试过
$(document).ready(function(){
alert(jQuery.inArray("Aborremåla", allaOrter));
});
但会导致“-1”(未找到)。
我正在尝试找出数组中项目的索引nr。有什么想法吗?
记录结果:
答案 0 :(得分:3)
这里的问题是json_encode($result);
创建了一个JSON 对象,而不是一个数组。因此jQuery.inArray
无效。
改为构建JavaScript数组:[ "value", "value", "value", etc... ];
或者用对象执行类似的操作:
var locations = {
"Abårremöla" : 1,
"Stuff" : 2,
"Ludvika" : 1549
};
var query = "Ludvika";
if(query in locations) {
var id = locations[query];
alert(id); //displays 1549
}
为了实现这一点,你必须在PHP中以相反的方式构建对象 - 所以PHP数组的位置名称作为索引器,id作为值:
$query = mysql_query("SELECT ort_id, ortnamn FROM geo_orter");
while(($row = mysql_fetch_assoc($query))){
$index = $row['ortnamn']; //<- note!
$result[$i] = $row['ort_id']; //<- note!
};
$allaOrterjson=json_encode($result);
答案 1 :(得分:0)
试试这个
var my_cars= new Array()
my_cars[0]="Mustang";
my_cars["family"]="Station Wagon";
my_cars["big"]="SUV";
for( var i in my_cars ){
console.log( my_cars[i] );
}
var n = {
"0": "Mustang",
"family": " Station Wagon",
"big": "SUV"
};
for( var i in n ){
console.log( n[i] );
}