使用PHP数组

时间:2015-09-17 04:39:10

标签: javascript php jquery autocomplete

我是JavaScript和JQuery的相对noob,但我已经在网上搜索了几个小时来找到这个问题的答案。我尝试使用PHP制作的数组填充JQuery自动完成功能。这是数组的片段:

<?php
    $arr = array(
        "Abaddon" => "/BlinkDaggerSounds/abad_blink_01.mp3",
        "Alchemist" => "/BlinkDaggerSounds/alch_blink_01.mp3",
        "Anti Mage" => "/BlinkDaggerSounds/anti_blink_01.mp3",
        "Ancient Apparition" => "/BlinkDaggerSounds/appa_blink_01.mp3",
        "Axe" => "/BlinkDaggerSounds/axe_blink_01.mp3", 
    );
?>

以下是我试图运行的脚本:

<script>
    $(function() {

        var availableTags = <?php echo json_encode($arr); ?>

        $( "#auto" ).autocomplete({
            source: availableTags;
        });

    });
</script>

以下是表格:

<form method="post" action="BlinkDaggerQuiz.php" class="answer_box">
    <p>Which hero is it?  <input type="text" id="auto" name="guess" /></p>
</form>

我的头标记:

<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <link rel="stylesheet" type="text/css" href="BlinkDaggerQuiz.css">
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>
</head>

我无法弄清楚我错过了什么;自动填充选项不会显示在文本框中。我也尝试用implode()代替json_encode(),但得到了相同的非结果。

2 个答案:

答案 0 :(得分:4)

我相信您当前的代码应该返回一些语法错误。点击F12然后找出答案。

您似乎正在尝试使用jQuery UI中的Autocomplete小部件。普通的旧jQuery中没有内置自动完成功能,因此您还必须包含jQuery UI。

这部分是JavaScript:

$( "#auto" ).autocomplete({
    source: availableTags;
    });
});

这意味着availableTags也需要是一个JavaScript数组。 JavaScript数组最简单的语法是var myArray = ['a', 'b', 'c'];

您需要将PHP数组输出到JavaScript数组中,可以使用implode函数完成。如果给定数组,implode函数将加入该数组中的所有。在您的情况下,您希望数组的位于数组中,而不是。因此,您可以使用array_keys函数检索给定数组中的所有键。你最终会得到:

var availableTags = [<?php echo '"' . implode ('","', array_keys ($arr)) . '"'; ?>];

当你的页面加载时,你应该得到一个合适的JavaScript数组:

var availableTags = ["Abaddon","Alchemist", "Anti Mage", "Ancient Apparition", "Axe"];

据我所知,没有名字中有双引号的Dota英雄所以使用双引号作为字符串应该没问题。

答案 1 :(得分:0)

确保链接到文件

<!-- html -->
<link rel="stylesheet" href="//code.jquery.com/ui/1.11.4/themes/smoothness/jquery-ui.css">
<script src="//code.jquery.com/jquery-1.10.2.js"></script>
<script src="//code.jquery.com/ui/1.11.4/jquery-ui.js"></script>
<link rel="stylesheet" href="/resources/demos/style.css">

自动完成功能适用于

等数组

var availableTags = ["Abaddon","Alchemist", "Anti Mage", "Ancient Apparition", "Axe"];

所以你需要根据需要改变这个......

<?php
$new_arr = array();
$arr = array(
    "Abaddon" => "/BlinkDaggerSounds/abad_blink_01.mp3",
    "Alchemist" => "/BlinkDaggerSounds/alch_blink_01.mp3",
    "Anti Mage" => "/BlinkDaggerSounds/anti_blink_01.mp3",
    "Ancient Apparition" => "/BlinkDaggerSounds/appa_blink_01.mp3",
    "Axe" => "/BlinkDaggerSounds/axe_blink_01.mp3", 
);
    foreach ($arr as $key => $value) {
    $new_arr[] = $key;// or $value
    }
?>
<script>
$(function() {

    var availableTags = <?php echo json_encode($new_arr); ?>


   $("#auto").autocomplete({
       // source: availableTags;  // autocomplete source is not include ";" (semicolon)
          source: availableTags   //correct
   });

});
</script>