[英]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.