Javascript 如何区分jquery上使用codeigniter从mysql获取数据的两个数组
你知道,我真的把jquery和codeigniter混淆了。我创建了一个web应用程序来监视来自用户的请求表单。 我有一个html视图,其中显示了如下表格:Javascript 如何区分jquery上使用codeigniter从mysql获取数据的两个数组,javascript,php,jquery,codeigniter,Javascript,Php,Jquery,Codeigniter,你知道,我真的把jquery和codeigniter混淆了。我创建了一个web应用程序来监视来自用户的请求表单。 我有一个html视图,其中显示了如下表格: +---------------+--------------------+ | id_request | comment_bapak | +---------------+--------------------+ | 001 | | | 002
+---------------+--------------------+
| id_request | comment_bapak |
+---------------+--------------------+
| 001 | |
| 002 | |
| 003 | |
+---------------+--------------------+
当用户插入“comment_bapak”列时,我想在jquery或javascript中创建一些警报。所以,我在jquery上使用autorefresh页面。比方说,插入一个用户“这是id请求002的注释”,然后在web上显示警报(“请求002已插入”)
,表格将像这样刷新
+---------------+---------------------------------+
| id_request | comment_bapak |
+---------------+---------------------------------+
| 001 | |
| 002 |This is comment of id_request 002|
| 003 | |
+---------------+---------------------------------+
这是我的代码
型号
public function getKomentarMD() {
$this->db->select('id_request, comment_bapak');
$query = $this->db->get('tbl_requestfix');
return $query->result_array();
}
控制器
public function getKomentarMD() {
$row = $this->model_request->getKomentarMD();
echo json_encode($row);
}
查看
<td class="sorting1" id='no_request' data-id-reseh="<?php echo $data['id_request']; ?>"><?php echo $data['id_request']; ?></td>
<td class="center" id="tanggap_md"><?php echo $data['jawaban_bapak']; ?> /td>
我有两个页面,第一个是用户表单,第二个是监控页面。两个页面具有相同的表显示。我的意思是,当用户更新表中的一行时,在该行已更新的监视页面上会有一个警报通知。所以我使用Jquery/Js来处理这个问题
我有这样的想法
+---------------+---------------------------------+
| id_request | comment_bapak |
+---------------+---------------------------------+
| 001 | |
| 002 |This is comment of id_request 002|
| 003 | |
+---------------+---------------------------------+
id,comment\u bapak
,并另存为第一个数组对象id、注释\u bapak
,并另存为第二个数组对象。所以,假设用户已经更新了一些行,和第一个数组对象会有区别。我说得对吗你知道吗?关于你的第一个问题:
console.log(obj)
的输出表明你得到了一个对象数组。我没有看到任何关于从数据库中选择特定行的内容,ajax响应包含所有行,而不仅仅是已更改的行。所以我怀疑你的方法就是接收所有的评论
您可以保留一个包含“current”注释的额外数组(这就是您在第二个问题中的意思吗?),并将其与json对象进行比较
在页面中,还可以使用javascript创建一个对象(“关联数组”):
var current_comments = {
1: null,
2: null.
3: null
);
包含数据库中的所有id和注释
然后,在ajax成功函数中,执行以下操作:
success: function(obj) {
var id, comment;
audioElement.play(); //playing tone
foreach (item in obj) {
id = parseInt(item['id_request'], 10);
comment = item['comment_bapak'];
if (current_comments[id] !== comment) {
// the comment changed!
alert(comment);// debugging
refreshAkibatCommentMD();
}
}
}
更新 (更新您的问题) 按照你的想法: 1:是的。这就是我建议的
current\u comments
对象。良好的起点
2和3:当然可以将ajax结果存储在单独的对象中,但这也是从ajax调用中得到的结果。因此,只遍历从ajax调用获得的对象更容易(并且使用更少的资源)。对于列表中的每个项目,您检查它是否等于“旧”情况。如果没有:警报
4:是的,当然您需要将新结果存储到第一个对象中(current\u comments
)
所以,基本上,你的建议已经在我的答案中了。我不确定函数refreshAkibatCommentMD()
的作用,但是如果您为它提供id
和comment
(在循环中),那么这个函数可以更新当前的\u comments
对象
success: function(obj) {
var id, comment;
audioElement.play(); //playing tone
foreach (item in obj) {
id = parseInt(item['id_request'], 10);
comment = item['comment_bapak'];
if (current_comments[id] !== comment) {
// the comment changed!
alert(comment);// debugging
refreshAkibatCommentMD(id, comment);
}
}
}
function refreshAkibatCommentMD(id, comment) {
// some logic to update the comment for row with id
}
小提示:您可能想了解一下javascript中数组和对象之间的差异。数组不能是“关联的”;在这种情况下,它将始终是一个对象!请参阅示例。关于Q1:您是否尝试使用
console.log(obj)代码>就在警报之前
?这将提供有关ajax调用实际返回内容的信息。请在您的问题中发布输出。你对Q2是什么意思?[Object{id\u request=“001”,comment\u bapak=“null”},Object{id\u request=“002”,comment\u bapak=null},Object{id\u request=“003”,comment\u bapak=null}。到目前为止你试过什么?什么不起作用?很乐意帮忙,但如果我不知道问题所在,就不可能想出办法。。。
success: function(obj) {
var id, comment;
audioElement.play(); //playing tone
foreach (item in obj) {
id = parseInt(item['id_request'], 10);
comment = item['comment_bapak'];
if (current_comments[id] !== comment) {
// the comment changed!
alert(comment);// debugging
refreshAkibatCommentMD(id, comment);
}
}
}
function refreshAkibatCommentMD(id, comment) {
// some logic to update the comment for row with id
}