今天在做个项目时,需要自定义树形栏目 并在树形栏目上做一些事件   这里我就写写梯归树形目录的大概方法

效果

JQ递归循环实现树形目录_d3

data数据结构

JQ递归循环实现树形目录_其他_02

//我的递归方法,HTML是我现在效果的HTML
function forAccess(data){
    var str="<div>";
    for(var i=0;i<data.length;i++){
       var leftPx = data[i].level*12;
       if(data[i].level == 1){
           cl = 'this';
       }else{
           cl = '';
       }
       str += '<div class="tree_content con_'+data[i].level+'"><div class="tree_name '+cl+' padding10" data="'+data[i].id+'">';
       str += '<img data="'+data[i].id+'" style="margin-left:'+leftPx+'px;" src="" class="node-img">'+data[i].name;
       str += '<div class="btn"><i class="layui-icon layui-icon-addition add"></i><i class="layui-icon layui-icon-edit edit"></i><i class="layui-icon layui-icon-close del"></i></div></div>';
        //在这里判断child是否存在
        if(data[i].list&&data[i].list.length>0){
            str+=forAccess(data[i].list);
        }
        str+="</div>";
    }
    str+="</div>";
    return str;//这里返回拼接的字符串
}

//使用
var htm = forAccess(data)
$(".treeitem").html(htm);