首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用javascript替换单元格中的元素?json来自Progress-4GL DB

如何使用javascript替换单元格中的元素?json来自Progress-4GL DB
EN

Stack Overflow用户
提问于 2021-01-20 21:47:36
回答 1查看 32关注 0票数 0

我对Progress和JavaScript都不熟悉。我正在使用json从Progress中的临时表中获取元素。我将展示我的部分代码。

代码语言:javascript
复制
$.post({
    url: gWS + "/bass/bass054.p",
    data: {
        "process": "<?php echo $process; ?>"
    },
    success: function(data){

    var table = document.getElementById("table");
    var j = 0;
    var dataProc = "";
    var qtProc = 0;
    var item = "";
    var sumQt = 0;
    var qt_total = 0;
    var idGrp = "";
    for (var i = 0; i < data["tt-base"].length; i++) {
        var row = table.insertRow(j+2);
        
        if (data["tt-base"][i]["cod_id_bloco_edi"] != idGrp && i>=2) {
            if (sumQt == qt_total) {
                row.style.background = "green";
            } else {
                row.style.background = "#ff0000";
            }
            row.insertCell(0).innerHTML = "<b>QT TOTAL:</b>";
            row.insertCell(1).innerHTML = "<b>" + item + "</b>";
            row.insertCell(2).innerHTML = "<b>" + sumQt + "</b>";
            row.insertCell(3).colSpan = "2";
            row.insertCell(4).innerHTML = "<b>" + qt_total + "</b>";
            sumQt = 0;
            j++;
            row = table.insertRow(j+2);
        }
         if (data["tt-base"][i]["cdn_segment_edi"] == 44) {
            row.style.background = "#00ff00";
            dataProc = data["tt-base"][i]["dsl_dados_entr_edi"].substring(7,9) + "/" + data["tt-base"][i]["dsl_dados_entr_edi"].substring(5,7) + "/20" + data["tt-base"][i]["dsl_dados_entr_edi"].substring(3,5) + "</div>";
            qtProc = parseInt(data["tt-base"][i]["dsl_dados_entr_edi"].substring(11,20), 10) + "</div>";
            row.insertCell(0).innerHTML = dataProc;
            row.insertCell(1).innerHTML = qtProc;
            row.insertCell(2).innerHTML = "&nbsp;";
            row.insertCell(3).colSpan = "2";
            row.insertCell(4).innerHTML = "<div class='p6'>&nbsp;</div>";
            j++;
            sumQt = parseInt(sumQt,10) + parseInt(qtProc,10);
            
        } else if (data["tt-base"][i]["cdn_segment_edi"] == 446) {
            if (data["tt-base"][i]["dsl_dados_entr_edi"].indexOf("PRE") == 10) {
                document.getElementById("table").deleteRow(j+1);
                j--;
                row = table.insertRow(j+2);
                row.style.background = "#0099CC";
                row.insertCell(0).innerHTML = dataProc;
                row.insertCell(1).innerHTML = qtProc;
                row.insertCell(2).innerHTML = "PREVIS";
                row.insertCell(3).colSpan = "2";
                row.insertCell(4).innerHTML = "<div class='p6'>&nbsp;</div>";
                dataProc = '';
                qtProc = 0;
                j++;
                
            } else if (data["tt-base"][i]["dsl_dados_entr_edi"].indexOf("FIR") == 10) {
                document.getElementById("table").deleteRow(j+1);
                j--;
                row = table.insertRow(j+2);
                row.style.background = "#00ff00";
                row.insertCell(0).innerHTML = dataProc;
                row.insertCell(1).innerHTML = qtProc;
                row.insertCell(2).innerHTML = "FIRM";
                row.insertCell(3).colSpan = "2";
                row.insertCell(4).innerHTML = "<div class='p6'>&nbsp;</div>";
                dataProc = '';
                qtProc = 0;
                j++;
                
            }
        }
        
        idGrp = data["tt-base"][i]["cod_id_bloco_edi"];
    }
}
}).fail(function() {
    alert("Not Possible.");
})

因此,我不想像现在这样删除行,而是将以前的只删除单元格替换为FIRM and PREVIS。我试着只使用row.insertCell(2).innerHTML = "PREVIS";,但它不能正常工作。我该怎么做,有什么建议吗?抱歉,如果我不够清楚,因为我是新手。耽误您时间,实在对不起。

EN

回答 1

Stack Overflow用户

发布于 2021-01-20 22:20:25

在调整了几个小时之后,我成功地做了我想做的事情,哈哈。我没有使用insertRow或insertCell,而是使用了以下内容

代码语言:javascript
复制
table.rows[j+2].style.background = "#0099CC";
table.rows[j+2].cells[2].innerHTML = "PREVIS";

这样,我就可以替换我想要的内容了。我还需要修改其他一些细节,但最困难的部分终于消失了。如果我浪费了您的时间,很抱歉,但是在这里编写代码帮助我从不同的角度来看待代码。我希望我的代码能帮助其他人。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65810805

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档