【发布时间】:2013-06-14 04:36:44
【问题描述】:
我想使用 codeigniter 和 jquery 和 mysql 进行实时搜索 但是当我输入一些东西时结果没有显示
这是我的型号代码:
<?php
class artikel_model extends CI_Model {
function __construct()
{
// Call the Model constructor
parent::__construct();
}
function cari_artikel($q)
{
$this->db->select('judul,contain');
$this->db->like('judul', $q);
$this->db->or_like('contain', $q);
$query = $this->db->get('artikel');
return $query->result_array();
}
}
?>
这是我的控制器代码:
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
class Welcome extends CI_Controller {
public function __construct()
{
parent::__construct();
$this->load->model('artikel_model');
}
public function index()
{
if(isset($_GET['q']) && $_GET['q']){
$q = $this->input->get('q');
$this->data['data']=$this->artikel_model->cari_artikel($q);
}
else{
$this->data['data']=array_fill_keys(array('judul', 'contain'), NULL);
}
$this->data['body']='dashboard';
$this->load->view('welcome_message',$this->data);
}
}
/* End of file welcome.php */
/* Location: ./application/controllers/welcome.php */
这是我的视图代码
<?php $this->load->helper('html');?>
<div class="row">
<div class="span12 offset3">
<form class="form-inline" name="form1" method="get" action="">
Search : <input type="text" class=span5 name="q" id="q"/> <label for="mySubmit" class="btn btn-primary"><i class="icon-search icon-white"></i></label> <input id="mySubmit" type="submit" value="Go" class="hidden" />
</form>
</div>
</div>
<?php echo br(15); ?>
<div id="result"></div>
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.5.2/jquery.min.js"></script>
<script type="text/javascript">
var allow = true;
$(document).ready(function(){
$("#q").keypress(function(e){
if(e.which == '13'){
e.preventDefault();
loadData();
}else if($(this).val().length >= 2){
loadData();
}
});
});
function loadData(){
if(allow){
allow = false;
$("#result").html('loading...');
$.ajax({
url:'http://localhost/helpdesk?q='+escape($("#q").val()),
success: function (data){
$("#result").html(data);
allow = true;
}
});
}
}
</script>
<?php
foreach($data as $row){ ?>
<h3><?php echo $row['judul']; ?></h3>
<?php } ?>
实时搜索不起作用。 当我输入一些东西时,输出只是“正在加载......” 结果没有显示..
如果我按回车,结果将显示。但这只是通常的搜索方法。不是实时搜索。
【问题讨论】:
-
回显您上次执行的查询。在firebug中控制台它你可以很容易地找到问题..在返回结果之前使用' echo $this->db->last_query(); '
-
您的 ajax 调用正在调用 URL
ajax-search.php,这是一个单独的文件,不在您的控制器中。这个文件存在吗?如果确实存在,您也可以发布吗? -
ajax-search.php?q=... 如果您调用控制器然后只传递该控制器名称/函数名称,这是不礼貌的使用方式。 var q =$("#q").val(); $.ajax({ type: "POST", dataType: 'json', url: "=site_url('Welcome')?>", data: {q: q}, cache: false, success: function(data ){警报(数据)}
-
@user1612290:哦,对不起,正确的不是
ajax-search.php,而是http://localhost/helpdesk,这是控制器工作的地方.. -
我将假设
http://localhost/helpdesk/调用您的index()控制器的index()函数(如果不忽略这个)。如果是这种情况,您是否有任何东西(视图等)正在打印要通过 AJAX 调用返回的 HTML?看起来如果您现在运行代码,它将传回一个全新的页面以插入到#resultdiv 中。
标签: php jquery mysql codeigniter