首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在不改变现有json数组值的情况下克隆json数组

如何在不改变现有json数组值的情况下克隆json数组
EN

Stack Overflow用户
提问于 2015-05-07 06:20:46
回答 2查看 102关注 0票数 2

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

代码语言:javascript
复制
[{
    "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
    }]
}]

现在,我在下面的函数中为这个数组移位智能进行分组

我已将以上JSON分配给

var ParsedJson = above JSON.

为此,我将使用以下功能:

代码语言:javascript
复制
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。如何防止它被更新?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-05-07 06:39:23

您可以使用jQuery.extend()

代码语言:javascript
复制
var ParsedJson = jQuery.extend(true, {}, YOUR_JSON);
票数 2
EN

Stack Overflow用户

发布于 2015-05-07 06:36:33

用这个:

代码语言:javascript
复制
var secondJSON = Object.create( firstJSON ).

第二个json现在独立于第一个json。

developer.mozilla.org/object/create

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

https://stackoverflow.com/questions/30093329

复制
相关文章

相似问题

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