javascript - 如何克隆 json 数组而不更改现有 json 数组的值

标签 javascript jquery arrays json

我有一个如下所示的 JSON 数组

[{
    "shiftNo": "shift 1",
    "UserId": 4,
    "UserName": "Felicia Frazier",
    "opnAmt": 0,
    "ClsAmt": 0,
    "RegisterName": "kano",
    "RegisterId": 2,
    "ZId": 19,
        "OpenDate": "2014-11-24 08:51:56.000",
    "CloseDate": "2014-11-24 16:58:02.000",
    "Total": 21.83,
        "PaymentDetails": [{
        "PayId": 1,
        "PaymentName": "Cash",
        "PaidAmount": 0
    }, {
        "PayId": 2,
        "PaymentName": "Check",
        "PaidAmount": 0
    }, {
        "PayId": 3,
        "PaymentName": "Credit Card",
        "PaidAmount": 21.83
    }]
},

{
    "shiftNo": "shift 1",
    "UserId": 5,
    "UserName": "Dewayne Frazier",
    "opnAmt": 0,
    "ClsAmt": 0,
    "RegisterName": "kano",
    "RegisterId": 2,
    "ZId": 19,
        "OpenDate": "2014-11-24 08:51:56.000",
    "CloseDate": "2014-11-24 16:58:02.000",
    "Total": 26.2,
        "PaymentDetails": [{
        "PayId": 1,
        "PaymentName": "Cash",
        "PaidAmount": 5.45
    }, {
        "PayId": 2,
        "PaymentName": "Check",
        "PaidAmount": 0
    }, {
        "PayId": 3,
        "PaymentName": "Credit Card",
        "PaidAmount": 20.75
    }]
},


{
    "shiftNo": "shift 2",
    "UserId": 5,
    "UserName": "Dewayne Frazier",
    "opnAmt": 202.91,
    "ClsAmt": 0,
    "RegisterName": "kano",
    "RegisterId": 6,
    "ZId": 20,
        "OpenDate": "2014-11-24 10:32:23.000",
    "CloseDate": "2014-11-24 22:01:37.000",
    "Total": 2380.69,
        "PaymentDetails": [{
        "PayId": 1,
        "PaymentName": "Cash",
        "PaidAmount": 818.65
    }, {
        "PayId": 2,
        "PaymentName": "Check",
        "PaidAmount": 90.1
    }, {
        "PayId": 3,
        "PaymentName": "Credit Card",
        "PaidAmount": 1471.94
    }]
},

{
    "shiftNo": "shift 2",
    "UserId": 7,
    "UserName": "Kelvin Daniels",
    "opnAmt": 100,
    "ClsAmt": 0,
    "RegisterName": "kano",
    "RegisterId": 6,
    "ZId": 20,
        "OpenDate": "2014-11-24 10:32:23.000",
    "CloseDate": "2014-11-24 22:01:37.000",
    "Total": 1516.33,
        "PaymentDetails": [{
        "PayId": 1,
        "PaymentName": "Cash",
        "PaidAmount": 1516.33
    }, {
        "PayId": 2,
        "PaymentName": "Check",
        "PaidAmount": 0
    }, {
        "PayId": 3,
        "PaymentName": "Credit Card",
        "PaidAmount": 0
    }]
}]

现在我正在下面的函数中对此数组进行 Shift Wise 分组

我已经在

中分配了上面的 JSON

var ParsedJson = 以上 JSON。

我为此使用以下函数:

var SubGridResult = getShiftReportSubGridGroupedValue(ParsedJson, groupColumnName, RegisterName);

function getShiftReportSubGridGroupedValue(sourceResult, groupColumnName, RegisterName) {

    //ParsedJson.filter(function (v) { return v[groupColumnName] == getRemovedCountFormatedValue(jQuery('#tblShiftSummaryReport').jqGrid('getCell', row_id, groupColumnName).trim()) }),
    var pGroupedResult = new Array();
    var GroupedResult1 = sourceResult.slice();
    var GroupedResult1234 = GroupedResult1.filter(function (v) { return v[groupColumnName] == RegisterName });

    $.each(GroupedResult1234, function (index, item) {
        var itemResult = new Array();
        itemResult = pGroupedResult.filter(function (value) { return value["shiftNo"] == item["shiftNo"] });
        if (itemResult.length > 0) {
            itemResult[0].ItemCount++;
            itemResult[0].opnAmt += parseFloat(item["opnAmt"]);
            itemResult[0].ClsAmt += parseFloat(item["ClsAmt"]);
            itemResult[0].Total += parseFloat(item["Total"]);
            var itemmm = itemResult[0].GroupedPaymentDetails;
            $.each(itemResult[0].GroupedPaymentDetails, function (indexIn, itemIn) {
                itemResult[0].GroupedPaymentDetails[indexIn]["PaidAmount"] += parseFloat(item["PaymentDetails"][indexIn]["PaidAmount"]);
            });
        } else {
            var newItemObj = new Object();
            newItemObj.ItemCount = 1;
            newItemObj.shiftNo = item["shiftNo"];
            newItemObj.RegisterName = item["RegisterName"];
            newItemObj.opnAmt = parseFloat(item["opnAmt"]);
            newItemObj.ClsAmt = parseFloat(item["ClsAmt"]);
            newItemObj.GroupedPaymentDetails = new Array();
            newItemObj.GroupedPaymentDetails = item["PaymentDetails"].slice();
            newItemObj.Total = parseFloat(item["Total"]);



            pGroupedResult.push(newItemObj);
        }
    });
    return pGroupedResult;
};

第一次它给了我一个正确的结果,但随后新数据也更新为我的原始 JSON。如何防止其被更新?

最佳答案

您可以使用jQuery.extend() :

var ParsedJson = jQuery.extend(true, {}, YOUR_JSON);

关于javascript - 如何克隆 json 数组而不更改现有 json 数组的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30093329/

相关文章:

javascript - AJAX 加载内容中未定义 bootstrap-datepicker

javascript - React - 捕获 shouldComponentUpdate 中的中间体

javascript - 输入永远不会从 Angular 获取 ng-invalid-class

jquery - 在调用 toggle() 之前 Div 淡出

javascript - onClick事件和IE

javascript - Myghtyslider chavroka 的 slider 宽度自动缩放

python - 为什么在 numpy 数组小数的切片赋值期间消失了?

javascript - 如何确定 Node 模块是否可以使用 Webpack 捆绑并在浏览器中运行?

c - 用指针打印 abc

c - 为什么 sizeof() 对于 int 数组没有给出不同的结果?