坚持使用Codeigniter和jQuery.ajax

时间:2011-03-05 13:43:33

标签: php ajax codeigniter jquery

所以......感谢stackoverflow用户之一,我尝试在我现有的Codeigniter应用程序中实现this精彩功能......

在我看来,我有这个:

<script type="text/javascript">
$(function() {
    $(".submit_op").click(function() {
        var dataString = $("#op_form").serialize();
        var url = "<?php echo site_url('submit/insert_data'); ?>";
        $.ajax({
            type: "POST",
            url: url+"/"+dataString,
            data: dataString,
            cache: false,
            success: function(html){
                //$("div#op").prepend(html); //PROBLEM HERE???
                $("div#op").prepend("<div>TEST</div>");
                $("div#op div:first").fadeIn("slow");
                //$("#debug").append("<font color=green><b>OK!</b></font> : " + dataString + "<br/>");
            },
            error: function(html){
                //$("#debug").append("<font color=red><b>ER!</b></font> : " + dataString + "<br/>");
            }
        });
        return false;
    });
});
</script>

<div id="debug"></div>

<?php
//here goes some data from db... newly added div should go in top of other divs
foreach ($some_data_sent_from_controller as $var) {
    echo "<div id=\"op\">";
    echo "<table width=\"100%\" border=\"0\">";
    //showing data
    echo "</table>";
    echo "</div>";
}

echo "<form action=\"#\" id=\"op_form\">";
//some clickable stuff...
echo br().form_submit('submit', 'OK', 'class="submit_op"');
echo "</form>";

在我的控制器中,我有一个处理从View发送的数据的函数:

function insert_data($input) {
    $this->load->model('blah_model');
    //processing serialized data and sending it to corresponding tables via Model
    $this->blah_model->add_to_table($some_data);
    $this->blah_model->add_to_another_table($some_other_data);

}

模特并不是一个大人物:)

function add_to_table($data){
            //processing data...
    $insert = $this->db->insert('my_table', array('array_which_contains_actual_data'));
    if ($insert == TRUE) {
        return TRUE;
    } else {
        return FALSE;
    }
}
//etc.

据我所知,我的问题不在于我的MVC模式,因为每次提交表单时,数据都会正确地插入到我的关系数据库中的所有可能的表中......但是新添加的行只是赢了“除非我刷新页面否则显示。

我认为我在jQuery.ajax行中做错了...如果我用这行$("div#op").prepend("<div>TEST</div>");运行我的脚本,当我提交表单时,我得到了期望的结果 - text {{ 1}}每次提交时都会显示在我的页面顶部...但如果我将该行更改为TEST,则在刷新之前不会显示任何内容...

我在这里做错了什么?

非常感谢您的帮助!

1 个答案:

答案 0 :(得分:1)

哇,这可能是我的蹩脚......但最后我发现我必须在控制器中回显我的结果,而不是返回它...所以当我将控制器中的功能更改为< / p>
function insert_data($input) {
    $str = "<div>KILLROY WAS HERE!</div>";
    echo $str; // <----- !!!!!!
}

我可以在我的页面上看到一条消息......

现在对其他事情......感谢自我头脑风暴:)