>  기사  >  웹 프론트엔드  >  js는 json 데이터의 트리 파티셔닝을 수행합니다.

js는 json 데이터의 트리 파티셔닝을 수행합니다.

小云云
小云云원래의
2018-03-07 13:48:491333검색

이 기사에서는 주로 js를 사용하여 반환된 json 데이터를 트리로 나누는 예제 코드를 공유합니다.

 $.ajax({
    type: "get",
    url: 'data.json',
    success:function(data){
    var jsondata = JSON.parse(data); //返回的数据是json字符串,把它转换成json对象,如果是json对象则不需转换
    var topArr = []; //声明一个数组,存储所有的json数据
    for (var i = 0; i< jsondata.length; i++) {        if (jsondata[i].parentid == 0) {
            jsondata[i].data = []; //给一级菜单下面添加data数据,存放二级菜单
            topArr.push(jsondata[i]);  //得到一级菜单
        }
    }    for (var j = 0; j < topArr.length; j++) {       for (var i = 0; i < jsondata.length; i++) {           if (jsondata[i].parentid == topArr[j].id) {
               jsondata[i].data = [];
               topArr[j].data.push(jsondata[i]);  //把获取的二级菜单存放到一级菜单的data对象中
           }
       }
   }    for (var j = 0; j < topArr.length; j++) {        for (var m = 0; m < topArr[j].data.length; m++) {            for (var i = 0; i < jsondata.length; i++) {                if (jsondata[i].parentid == topArr[j].data[m].id)    {
                   topArr[j].data[m].data.push(jsondata[i]); //把获取的三级菜单存放到二级菜单的data对象中
                }
            }
        }
    }
    }
});
               
 $.ajax({
    type: "get",
    url: &#39;data.json&#39;,
    success:function(data){
    var jsondata = JSON.parse(data); //返回的数据是json字符串,把它转换成json对象,如果是json对象则不需转换
    var topArr = []; //声明一个数组,存储所有的json数据
    for (var i = 0; i< jsondata.length; i++) {        if (jsondata[i].parentid == 0) {
            jsondata[i].data = []; //给一级菜单下面添加data数据,存放二级菜单
            topArr.push(jsondata[i]);  //得到一级菜单
        }
    }    for (var j = 0; j < topArr.length; j++) {       for (var i = 0; i < jsondata.length; i++) {           if (jsondata[i].parentid == topArr[j].id) {
               jsondata[i].data = [];
               topArr[j].data.push(jsondata[i]);  //把获取的二级菜单存放到一级菜单的data对象中
           }
       }
   }    for (var j = 0; j < topArr.length; j++) {        for (var m = 0; m < topArr[j].data.length; m++) {            for (var i = 0; i < jsondata.length; i++) {                if (jsondata[i].parentid == topArr[j].data[m].id)    {
                   topArr[j].data[m].data.push(jsondata[i]); //把获取的三级菜单存放到二级菜单的data对象中
                }
            }
        }
    }
    }
});

관련 권장 사항:

php에서 json 데이터 코드를 읽는 방법

PHP가 반환된 JSON 데이터를 gzip 출력으로 압축하는 방법에 대한 자세한 설명

JavaScript가 JSON 데이터를 정렬하고 검색하는 방법에 대한 자세한 예

위 내용은 js는 json 데이터의 트리 파티셔닝을 수행합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.