繁体   English   中英

cakephp 2.4中的自动完成实现

[英]Autocomplete implementation in cakephp 2.4

大家好,我是Cakephp的新手,我想在我的项目中实现自动完成功能。 我已经下载了两个JavaScript文件jquery.autocomplete.js和jquery.autocomplete.min.js并将它们都放在我的webroot目录中。 我的数据库中有一个名为city的字段,我必须自动完成。 问题是我的sutocomple没有启动,甚至在按下键时也没有显示警报。

我的JavaScript代码是

 <script src="../../webroot/js/jquery.autocomplete.js" 
  type="text/javascript"></script>
 <script src="../../webroot/js/jquery.autocomplete.min.js" 
 type="text/javascript"></script>
 $(function() {
 $('#Usercity').autocomplete({
     alert("ashish");

    //dataType: "json"
    minLength: 1,
    source: function( request, response ) {
        $.ajax({
            url: "/User/autoComplete",
            dataType: "jsonp",
            data: {
                featureClass: "P",
                style: "full",
                maxRows: 12,
                term: request.term
            },
            success: function( data ) {
                response( $.map( data, function( el ) {
                    return { label: el.id, value: el.city }
                }));
            }
        });
    }

   });

    });
  </script>
           echo $this->Form-
   >input('city',array('type'=>'text','label'=>'City'));


   Controller code


       public function autoComplete() {
    Configure::write('debug', 0);
    $this->layout = 'ajax';
    $query = $_GET['term'];
    $items = $this->User->find('all', array(
        'conditions' => array('User.city LIKE' => $query . '%'),
        'fields' => array('city')));

    foreach ($items as $item) {
        $data[] = $item['Item'];
    }
    $data = json_encode($data);
    echo $data;
    exit;
}

}

解决问题

问题是我的sutocomple没有启动,甚至在按下键时也没有显示警报。

您需要在autocomplete.js之类的东西之前加载jQuery lib

<script src="../js/jquery-last.version.number.js"></script>

或者如果您想让cakephp为您做这件事(无需编写“ .js”)

            echo $this->Html->script(array(
                'jquery-1.10.2.min',
                'jquery.autocomplete'
            ));

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM