Я довольно новичок в jQuery (с недели) и не понимаю, почему я не могу присвоить массив PHP (work.php) глобальному var imgArrayThumbs
. Я вызываю массив имен изображений, созданных функцией php opendir
. Когда я 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');
}
functions.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