0

私はjQueryを初めて使用し(1週間以来)、PHP(work.php)配列をグローバル var に割り当てることができない理由を理解していませんimgArrayThumbs。phpopendir関数によって作成された画像名の配列を呼び出しています。私alert(imgArrayThumbs);がちょうど戻ってきたとき[object Object]。誰か助けてくれませんか?一日中それを理解しようとしてきました。

scripts.js

var imgArrayThumbs = '';

$.post("work.php", { task: "imgArrayThumbs" }, function(data) {
  imgArrayThumbs = data;
});

alert(imgArrayThumbs);

work.php

include_once 'scripts/functions.php';

if($_POST['task'] == 'imgArrayThumbs'){
  imageArray('source/examples/thumbs', 'imgArrayThumbs');
}
elseif ($_POST['task'] == 'imgArray'){
  imageArray('source/examples/', 'imgArray');
}

関数.php

function imageArray($dir, $arrayVar){
  $arrayName = array();

  $iNumber = 0;
  $open = opendir ($dir);
  while ($file = readdir( $open )){
    if($file == "." || $file == ".." || $file == ".DS_Store"){

    }else{ 
      $arrayName[$iNumber] = $file;
      $iNumber ++;
    }
  }
  closedir ( $open );

  for ($i = 0;$i<count($arrayName);$i++){ 
    if ($i == 0) { 
      echo "\"" . $arrayName[$i] . "\""; 
    }else{ 
      echo ",\"" . $arrayName[$i] . "\""; 
    } 
  } 
}

編集 01

作業バージョン:

scripts.js:

var imgArrayThumbs = new Array();   
$.ajaxSetup({async:false});
$.ajax({
  type: 'POST',
  url: 'work.php',
  data: { task: "imgArrayThumbs" },
  success: function(data) {
    imgArrayThumbs = data;
  },
  dataType: 'json'
});

functions.php:

echo json_encode($arrayName); // without loop
4

1 に答える 1

0

alert()しますtoString()。jQuery コードはオブジェクトを返すためalert、クラス タイプのみを出力します[object Object]。代わりに、Firebug のようなもの、または IE と Chrome の組み込みの開発者ツールを使用しimgArrayThumbs = data; console.log(imgArrayThumbs)、オブジェクトのコンテンツを参照する場合はコンソールを確認してください。

また、jQuery はデフォルトで JSON の結果を想定していますが、PHP コードはそれを適切な JSON に正確にフォーマットしていません。JSON でエンコードするはるかに簡単な解決策はfor、最後にループを削除し、echo json_encode($arrayName);代わりに使用することです。

于 2011-11-22T20:53:44.597 に答える