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 に答える