json不同格式转换。

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>json格式转换</title>
</head>
<body>
	<ul class="old"></ul>
	<script type="text/javascript">
		var old = {
            "goodsName": ["货品名称1", "货品名称2"],
            "goodsNumber": ["件数1", "件数2"],
            "goodsVolume": ["体积1", "体积2"],
            "goodsWeight": ["重量1", "重量2"],
            "productsNumber": ["商品数1", "商品数2"],
            "goodsValue": ["货值1", "货值2"],
            "goodsPackage": ["1", "2"],
            "goodsPrice": ["2", "3"]
        }
        //将上面的格式转成下面的格式。
        var b=[{
            "goodsName": "货品名称1",
            "goodsVolume": "件数1",
            "goodsNumber": "体积1",
            "goodsWeight": "重量1",
            "productsNumber": "商品数1",
            "goodsValue": "货值1",
            "goodsPackage": "1",
            "goodsPrice": "2"
        }, {
            "goodsName": "货品名称2",
            "goodsVolume": "件数2",
            "goodsNumber": "体积2",
            "goodsWeight": "重量2",
            "productsNumber": "商品数2",
            "goodsValue": "货值2",
            "goodsPackage": "2",
            "goodsPrice": "2"
        }];
	
        //第一种写法,需要后台传过来一共的总条数。
        var newArray=[];
        for(var i=0;i<old.goodsName.length;i++){
            var html={}; 
            for(var a in old){
                html[a]=old[a][i];
            }
            newArray.push(html);
        } 
        console.log(newArray);
        
        //第二种写法。
        var GoodData = [];
        for(var item in old){
            for (var j=0;j<old[item].length;j++){
                if(GoodData[j]){
                    GoodData[j][item] = old[item][j]
                 } 
                else{
                    GoodData[j] = {}
                    GoodData[j].item = old[item][j]
                }
            }
        }
        console.log(GoodData);
	</script>
</body>
</html>

  

转载于:https://www.cnblogs.com/chenwenhua/p/7280654.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值