当变量不是硬编码时,functions.php脚本会中断

时间:2013-09-06 20:31:36

标签: php javascript jquery json wordpress

我编写了一个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

2 个答案:

答案 0 :(得分:0)

是的,请检查您正在使用的字符编码。这可能是问题所在。

答案 1 :(得分:0)

感谢Marc的调试,结果证明了当我在页面中运行脚本时得到的结果。当我用javascript调用脚本时,我得到的是不同的。它尝试使用glob-ajax.php而不是URL。