所以......感谢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
,则在刷新之前不会显示任何内容...
我在这里做错了什么?
非常感谢您的帮助!
答案 0 :(得分:1)
function insert_data($input) {
$str = "<div>KILLROY WAS HERE!</div>";
echo $str; // <----- !!!!!!
}
我可以在我的页面上看到一条消息......
现在对其他事情......感谢自我头脑风暴:)