Javascript 如何区分jquery上使用codeigniter从mysql获取数据的两个数组

Javascript 如何区分jquery上使用codeigniter从mysql获取数据的两个数组,javascript,php,jquery,codeigniter,Javascript,Php,Jquery,Codeigniter,你知道,我真的把jquery和codeigniter混淆了。我创建了一个web应用程序来监视来自用户的请求表单。 我有一个html视图,其中显示了如下表格: +---------------+--------------------+ | id_request | comment_bapak | +---------------+--------------------+ | 001 | | | 002

你知道,我真的把jquery和codeigniter混淆了。我创建了一个web应用程序来监视来自用户的请求表单。 我有一个html视图,其中显示了如下表格:

+---------------+--------------------+
| 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         |                                 |
+---------------+---------------------------------+
  • 第一次加载监控页面时,从数据库调用all
    id,comment\u bapak
    ,并另存为第一个数组对象

  • 使用JS/Jquery上的自动刷新,使用ajax调用数据库中的所有
    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
    }