Codeigniter从数据库自动完成

时间:2013-05-31 15:48:48

标签: javascript database codeigniter autocomplete double-submit-problem

我的项目有些问题。我想在CodeIgniter中使用JavaScript进行自动完成。我已经尝试了很多选项,但它们不起作用!

控制器:

 public function getResult($referencia){
     if(!empty($referencia) || isset($referencia))
     {
        $this->db->like('referencia', $referencia);
        echo json_encode( $this->db->get('produto_servico_tbl')->result());
     }
 }

autocomplete.js(由我创建):

$(document).ready(function(){
    $('#search').keypress(function(e){
        if(e.which == 13)
        {
            e.preventDefault();
        }
        var searched = $('#search').val()
        var fullurl = $('#hiddenurl').val() +    'autoComplete_v.php/autoComplete_c/getResult/' + searched
        $.getJSON(fullurl,function(result){
            //display suggestion code goes here
            var elements = [];
            $.each(result, function(i, val){
                elements.push(val.referencia)
            })
            $('#search').autocomplete({
                source : elements
            })
        })
    })
})

观点:

<head>
<link href="<?=base_url()?>css/ui-lightness/jquery-ui-1.10.3.custom.css" media="screen" type="text/stylesheet" rel="stylesheet" />

<form>
    <label for="search">Search</label>
    <input id="search" type="text"/>
    <input value="<?=base_url()?>" id="hiddenurl" type="hidden">
    <input type="submit" value="submit"/>
</form>

<script src="<?=base_url()?>js/jquery-1.9.1.js" type="text/javascript"></script>
<script src="<?=base_url()?>js/jquery-ui-1.10.3.custom.min.js" type="text/javascript"></script>
<script src="<?=base_url()?>js/jquery-ui-1.10.3.custom" type="text/javascript"></script>
<script src="<?=base_url()?>js/autocomplete.js" type="text/javascript"></script>

1 个答案:

答案 0 :(得分:2)

您为AJAX调用提供了错误的URL。

更改此行:

var fullurl = $('#hiddenurl').val() +    'autoComplete_v.php/autoComplete_c/getResult/' + searched

此处$('#hiddenurl').val()是您的base_url()。所以完整的URL将是:

 var fullurl = $('#hiddenurl').val() +    'controller_class_name/getResult/' + searched

在CodeIgniter中,您的网址如下:

base_url/controller_class_name/method_name/parameter1/parameter2....

您的autocomplete_v.php将产生错误。您可以查看您的JavaScript如何与Firebug一起使用。