3

我在网上某处找到的这段代码运行良好,这正是我想要完成的:

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

日志结果: 登录

4

2 回答 2

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 中以另一种方式构建对象 - 因此使用位置名称作为索引器和 id 作为值的 PHP 数组:

$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);
于 2012-08-10T16:54:26.763 回答
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] );
}
于 2012-08-10T17:39:59.327 回答