我编写了一个jQuery脚本,它使用此函数生成的JSON编码列表在我的主题的functions.php中运行,并为我的jPlayer创建一个播放列表。但是,该脚本仅在$file
变量被硬编码时才起作用(例如,OH0400
)。但是我需要根据正在加载的页面来获取$file
变量。但是当我切换到这个方法(使用URL)时,脚本说JSON为null。
我以多种方式运行脚本,硬编码$file
和基于变量的$file
之间的输出看起来是相同的。当我进行切换时为什么会出现空值?
这是我的主题functions.php中的PHP。
function MyjPlayerList(){
$url = explode( '/', $_SERVER['REQUEST_URI'] );
$file = strtoupper($url[2]);
//$file = 'OH0400';
$filename = '/dir/oralhistory/mp3files/'.$file.'*.mp3';
$FILES = glob( $filename );
foreach( $FILES as $key => $mp3 ) {
$mp3 = str_replace( '/dir/oralhistory/mp3files/', '',$mp3);
$FILE_LIST[ $key ][ 'title' ] = $mp3;
$FILE_LIST[ $key ][ 'mp3' ] = 'http://websiteurl.org/mp3files/'.$mp3;
}
$myjplayerdata = json_encode( $FILE_LIST );
header ( 'Content-type: application/json' );
echo $myjplayerdata;
exit;
die();
};
这是我的javascript:
ajax_player = function() {
jQuery('div#player').load('/js/player.html' , function() {
var cssSelector= {
jPlayer: "#jquery_jplayer_1",
cssSelectorAncestor: "#jp_container_1"
};
var playlist = [];
var options = {
swfPath: "/js/Jplayer.swf",
supplied: "mp3",
smoothPlayBar: true,
keyEnabled: true
};
var myPlaylist = new jPlayerPlaylist(cssSelector, playlist, options);
jQuery.ajax({
url: "/wp-admin/admin-ajax.php" ,
type: "POST",
dataType: "text json",
data: { action: "MyjPlayerList"},
success:(function(data) {
jQuery.each(data, function(index, value){
myPlaylist.add(value); // add each element in data in myPlaylist
console.log(data);
})
})//function (data) close
})//ajax close
})//jquery.load
}//ajax_player
答案 0 :(得分:0)
是的,请检查您正在使用的字符编码。这可能是问题所在。
答案 1 :(得分:0)
感谢Marc的调试,结果证明了当我在页面中运行脚本时得到的结果。当我用javascript调用脚本时,我得到的是不同的。它尝试使用glob-ajax.php而不是URL。