私は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