来自php数组的inArray jQuery,找到项目索引

时间:2012-08-10 16:39:05

标签: php jquery arrays

我在网上找到的这段代码运行良好,这正是我想要实现的目标:

$(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。有什么想法吗?

记录结果: loggen

2 个答案:

答案 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] );
}