0

我正在尝试将 jquerys 自动完成与我的数据库一起使用,但我无法弄清楚如何从我的 php 脚本中返回数据作为自动完成的选项。

这是我目前基于另一个论坛帖子的内容:

$('input#transferto').autocomplete({
                source: function(request, response)
                {
                    alert('{"term": "'+request.term+'", "mode": "ENTITY_AUTOCOMPLETE"}');
                    $.ajax({
                        url: SYSTEM_ROOT+'/assets/controllers/global.php',
                        data: 'dataString={"term": "'+request.term+'", "mode": "ENTITY_AUTOCOMPLETE"}',
                        success: function(data)
                        {
                            //alert(data);
                            //data = $.parseJSON(data) ;
                            response($.map(data, function(item) {
                                return{
                                    label: item.user_login_name,
                                    value: item.user_id
                                }
                            }))
                        }
                    })
                },
                minLength: 3,
                datatype: 'json',
                cache: false,
                delay: 500,

在我的 php 文件中:

if($mode == 'ENTITY_AUTOCOMPLETE')
{
    $query = trim(strip_tags($JSON->term));
    $q = $query.'%' ;
    $result = $dbh->prepare("SELECT id, name FROM entity_details WHERE name LIKE ?") ;
    $result->execute(array($q)) ;

    //$data = '{' ;
    //while($row = $result->fetch(PDO::FETCH_ASSOC)) {
        //foreach($row as $key => $val)
            //$data .= '"'.$key.'": "'.rawurldecode($val).'", ' ;
    //}
    //$data = substr($data, 0, strlen($data)-2).'}' ;
    $data = $result->fetchAll(PDO::FETCH_ASSOC) ;
    echo print_r($data) ;
}

如您所见,我尝试只返回一个数组并尝试 JSON,但无济于事。

我如何使它工作?

4

1 回答 1

0

你读过文档吗?http://api.jquery.com/jQuery.ajax/

url: SYSTEM_ROOT+'/assets/controllers/global.php',

1) SYSTEM_ROOT 根是什么?你没有在任何地方定义这个。

data: 'dataString={"term": "'+request.term+'", "mode": "ENTITY_AUTOCOMPLETE"}',

2)您传递数据字符串的方式是不必要的。正如 jquery 文档指定的那样,如果还不是字符串,则将其转换为查询字符串并附加到 GET 请求的 url。如果你使用一个对象,它必须是一个键/值对。同时,您正在尝试将查询字符串中的对象作为字符串填充。

if($mode == 'ENTITY_AUTOCOMPLETE')

3)在这一行上,您的访问$mode未定义/声明。通常,您会使用 GET 请求进行检查,$_GET['mode']但在您的情况下,它不会在那里,因为您已经弄乱了您传递的数据(在 2 中提到)

打开 NET 面板并检查控制台是否存在要调试的错误。

于 2012-11-05T16:39:33.963 回答