JSON转数组后,筛选分组并输出,判断键值键值是否存在补0

简介: JSON转数组后,筛选分组并输出,判断键值键值是否存在补0
var arr = [
{“category_name”: “60米”, “member_name”: “张三”, “value”: “90”},
{“category_name”: “60米”, “member_name”: “李四”, “value”: “80”},
{“category_name”: “3000米”, “member_name”: “张三”, “value”: “46”},
{“category_name”: “负重”, “member_name”: “王五”, “value”: “23”},
{“category_name”: “负重”, “member_name”: “马六”, “value”: “85”},
{“category_name”: “100米”, “member_name”: “张三”, “value”: “79”}
];


var NameData = ['张三', '李四', '王五', '马六'];
var projectData = ['60米', '3000米', '负重', '100米'];
/*JSON数据分组转化设置*/
function createTree(arr, keys) {
  function createObj(arr, arrORobj, keys, start) {
    for (let i = 0; i < arr.length; i++) {
      if (start >= keys.length) {
        let newArray = Array.isArray(arrORobj) ? arrORobj : []
        return newArray.concat(arr[i])
      }
      let curKey = keys[start]
      let curVal = arr[i][curKey]
      if (!curVal)continue
      let newObj = arrORobj[curVal] ? arrORobj[curVal] : {}
      arrORobj[curVal] = createObj([arr[i]], newObj, keys, start + 1)
    }
    return arrORobj
  }
  return createObj(arr, {}, keys, 0)
}
//按照名字先分组,后按照项目分类,组成新的数组;
var nv = createTree(arr, ['member_name', 'category_name']);
console.log(nv);
//document.write(JSON.stringify(nv));
//document.write("<hr>");
//读取名字;
//document.write(arr[0].member_name);
//document.write("<br>");
//读取转换数组的值;
//document.write(JSON.stringify(nv[1][1][0]['value']));
//document.write(JSON.stringify(nv[NameData[0]]['60米'][0]['value']));
//document.write(JSON.stringify(nv[NameData[0]]['3000米'][0]['value']));
//document.write(JSON.stringify(nv[NameData[0]]['100米'][0]['value']));
//document.write("<hr>");
//判断数据某键值是否存在;
/*
 function typeArr(newArr, key) {
 if (newArr.hasOwnProperty(key)) {
 return nv[NameData[0]][projectData[key]][0]['value'];
 } else {
 return '0';
 }
 }
 */
//console.log(JSON.stringify(nv[NameData[0]]['100米'][0]['value']).hasOwnProperty('100米'));
/*判断项目键名中是否为空或未定义*/
function typeArr(newArr, key) {
  if (typeof(newArr) == 'undefined' ? false : (newArr.length == 0 ? false : true)) {
    return JSON.stringify(nv[NameData[0]][projectData[key]][0]['value']);
  } else {
    return "0";
  }
}
var brr = [];
brr[0] = JSON.stringify(nv[NameData[0]][projectData[0]][0]['value']);
brr[1] = JSON.stringify(nv[NameData[0]][projectData[1]][0]['value']);
brr[2] = typeArr(JSON.stringify(nv[NameData[0]][projectData[2]]), 2);
brr[3] = JSON.stringify(nv[NameData[0]][projectData[3]][0]['value']);
document.write('[' + brr + ']');
相关文章
|
1天前
|
存储 JSON 前端开发
JSON数组的概念、语法和用法
JSON数组的概念、语法和用法
213 3
|
1天前
|
JSON JavaScript 前端开发
前端 ex2json 用于 vue/react/js 将 xls、xlsx、csv 文件转成 json 数组
前端 ex2json 用于 vue/react/js 将 xls、xlsx、csv 文件转成 json 数组
97 0
|
6月前
|
JSON 前端开发 Java
Springboot接收ajax提交JSON数组
Springboot接收ajax提交JSON数组
|
1天前
|
存储 JSON DataWorks
DataWorks产品使用合集之DataWorks将 MongoDB 中的数组类型写入到 DataWorks 的单个字段时,表示为字符串格式而非 JSON 格式如何解决
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
26 3
|
1天前
|
SQL JSON Apache
Flink问题之嵌套 json 中string 数组的解析异常如何解决
Apache Flink是由Apache软件基金会开发的开源流处理框架,其核心是用Java和Scala编写的分布式流数据流引擎。本合集提供有关Apache Flink相关技术、使用技巧和最佳实践的资源。
229 1
|
8月前
|
JSON JavaScript 前端开发
Python中如何快速解析JSON对象数组
Python中如何快速解析JSON对象数组
99 0
|
8月前
|
存储 JSON JavaScript
|
1天前
|
JSON PHP 数据格式
php 删掉空的数组 json数据. 空数据(false 0 ““ null)
php 删掉空的数组 json数据. 空数据(false 0 ““ null)
php 删掉空的数组 json数据. 空数据(false 0 ““ null)
|
1天前
|
XML JSON 前端开发
教你怎么用ajax传数组(也可以是转为json)
教你怎么用ajax传数组(也可以是转为json)
35 0
|
1天前
|
JSON 数据格式
gson自定义Type解析json数组字符串
gson自定义Type解析json数组字符串

热门文章

最新文章