selectize.js - 使用 Selectize.js 从 SQL 远程加载数据

标签 selectize.js

您会注意到,我是一名数据科学家,而不是程序员/开发人员。

在 SQL 中,我有一个包含一万个名称的数据库。我设法在我的 twitter bootstrap 网站中实现了 selectize.js 工具,但它加载速度很慢。在 Selectize.js 的帮助页面上,https://github.com/brianreavis/selectize.js/blob/master/docs/usage.md ,我读到可以在用户输入内容时即时加载选项。

但是从示例中我无法找到如何从 SQL 表中执行此操作。有人可以用伪代码编写我必须做的事情吗?

简而言之,当用户键入一些名称时,我希望脚本在 SQL 表中查找这些名称并选择 html 标签,而不是在开始时就下载每个名称。

这是我目前的代码:

            <div class="control-group">
                <select id="select-yourself" class="demo-default" placeholder="Type your name...">
                    <option value="">Type your name ...</option>
                        <?php
                            for($row = 0; $row < sizeof($race_table); $row++){
                            echo("<option value=".$row.">".
                            $race_table[$row]['Name']."</option>");
                        }
                        ?>
                </select>
            </div>
            <script>
            $('#select-yourself').selectize({
                create: false,
                maxOptions: 100,
                //sortField: {
                    //field: 'text',
                    //direction: 'asc'
                //},
                dropdownParent: 'body'
            });

最佳答案

你可以尝试这样的事情:

HTML:

<div class="control-group">
  <select id="select-yourself" class="demo-default" placeholder="Type your name...">
    <option value="">Type your name ...</option>
  </select>
</div>

JavaScript:
$('#select-yourself').selectize({
  valueField: 'name',
  labelField: 'name',
  searchField: 'name',
  options: [],
  create: false,
  load: function(query, callback) {
    if (!query.length) return callback();
    $.ajax({
      url: 'http://127.0.0.1:8080/getnames.php',
      type: 'GET',
      dataType: 'json',
      data: {
        name: query,
      },
      error: function() {
        callback();
      },
      success: function(res) {
        callback(res);
      }
    });
  }
});

PHP 文件 (getnames.php) 仅用于从 mysql 数据库数据创建 json 文件:
<?php
// parameters from URL
$urlparam_name = $_GET['name'] ."%";

// connect to the database
include("mysql.inc");
$link = mysqli_connect($host, $user, $pass, $db) or die("Error " .mysqli_error($link));

$sql = "
SELECT `race_table`.`name`
FROM `race_table`
WHERE `race_table`.`name` like '$urlparam_name'
GROUP BY `race_table`.`name` ASC
";

$result = mysqli_query($link, $sql) or die("Error " .mysqli_error($link));
$rows = array();
while ($row = mysqli_fetch_assoc($result))
{
    extract($row);
    $rows[] = "{ \"name\": \"$name\" }";
}

// output to the browser
header('Content-Type: text/javascript; charset=UTF-8');
echo "[\n" .join(",\n", $rows) ."\n]";
?>

关于selectize.js - 使用 Selectize.js 从 SQL 远程加载数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29444430/

相关文章:

jquery - 禁用特定的 "selectize"下拉选项

javascript - 如何以编程方式隐藏选择选项?

javascript - Rails 选择 Gem 安装

jquery - 如何使用 Selectize 选择所有选项?

javascript - 选择带有 json 的 js 不起作用

javascript - 将 selectize.js 与远程源结合使用

javascript: selectize 默认选择第一项

r - 具有特征 "remove all-at-once"的 Shiny selectizeInput

javascript - 使用鼠标粘贴文本不会触发搜索

javascript - 如何使用 selectize.js 将数组值设置到文本字段中