如何将多个PHP变量传递给jQuery函数?

时间:2012-06-15 14:19:04

标签: php jquery ajax wordpress plugins

我正在使用Wordpress插件。我需要将插件目录(可以根据个人的安装而改变)传递给jquery函数。

这样做的最佳方式是什么?我可以处理的插件版本包含了PHP文件中的所有javascript,因此在浏览器中呈现之前,函数与其他内容一起被解析。

我正在研究AJAX,但我认为它可能比我需要的更复杂。在这种情况下,我只能使用两个变量(目录,没有用户设置)。

当我读到它的良好实践时,我试图将js和php分开。当插件初始化时,它会调用js文件:

    //Wordpress calls the .js when the plugin loads
    wp_enqueue_script( 'wp-backitup-funtions', plugin_dir_url( __FILE__ ) . 'js/wp-backitup.js', array( 'jquery' ) );

然后我在.js文件中,需要弄清楚如何生成以下变量:

    dir = '<?php echo content_url() ."/plugins"; ?>';
    dir = '<?php echo content_url() ."/themes"; ?>';
    dir = '<?php echo content_url() ."/uploads"; ?>';

运行解析以下请求:

    xmlhttp.open("POST","<?php echo plugins_url() .'/wp-backitup/includes/wp-backitup-restore.php'); ?>",true);
    xmlhttp.open("POST","<?php echo plugins_url() .'/wp-backitup/includes/wp-backitup-start.php'); ?>",true);
    xmlhttp.open("POST","<?php echo plugins_url() .'/wp-backitup/wp-backitup-directory.php'); ?>",true);
    xmlhttp.open("POST","<?php echo plugins_url() .'/wp-backitup/wp-backitup-db.php'); ?>",true);
    window.location = "<?php echo plugins_url() .'/wp-backitup/backitup-project.zip'); ?>"; 
    xmlhttp.open("POST","<?php echo plugins_url() .'/wp-backitup/wp-backitup-delete.php'); ?>",true);

内容URL和插件URL的区别仅在于/ plugins /所以如果我很难按,我只需要发一个PHP请求然后把它带到JS中。

3 个答案:

答案 0 :(得分:1)

您的函数可以加载到.js文件中,但是当您在PHP页面中对插件进行itiniatlize时,可以给出您需要的PHP变量。例如:

$("#myDiv").startPlugin("<?php echo $directory;?>");

如果您需要来自php的信息,您实际上无法选择将其提供给插件。用ajax查询它对我来说不是一个好主意。

答案 1 :(得分:1)

它没有看到代码那么难,但一般来说我会从php输出目录,如:

<script type="text/javascript">
  var dirs = <?php echo empty($dirs) ? "{}" : json_encode($dirs); ?>;
</script>

答案 2 :(得分:1)

又快又脏:

<script type="text/javascript">
<?php
    echo 'var myJsObject =' . json_encode(array(
        'dir1' => $directory1,
        'dir2' => $directory2
    ));
?>
    alert(myJsObject.dir1);
</script>