layui-Dtree树结构

简介: 这是一个关于layui-Dtree树结构的总结。Dtree是一个用于展示树形数据的组件,可以从[这个链接](https://www.wisdomelon.com/DTreeHelper/)下载。数据格式支持标准、list类型和layui+list集合,示例代码展示了如何渲染和配置这些格式。此外,Dtree提供了图标监听、节点监听和节点双击事件的回调功能。它还支持带复选框的节点,允许用户进行多选操作,并能获取选中节点的参数。最后,文章以一个简单的提交信息示例结束。

@[toc]

layui-Dtree树结构

看效果

image.png

一、Dtree的下载

https://www.wisdomelon.com/DTreeHelper/
image.png

二、数据格式

2.1 标准格式


dtree.render({
   
   
  elem: "#dataTree1",
  url: "../../../json/case/dataTree.json"
});

json的数据格式

{
   
   
"status":{
   
   "code":200,"message":"操作成功"},
"data": [
  {
   
   "id":"001","title": "湖南省","parentId": "0","children":[]},
  {
   
   "id":"002","title": "湖北省","parentId": "0","children":[]},
  {
   
   "id":"003","title": "广东省","parentId": "0","children":[]},
  {
   
   "id":"004","title": "浙江省","parentId": "0","children":[]},
  {
   
   "id":"005","title": "福建省","parentId": "0","children":[]}
]
}

2.2 list类型

dtree.render({
   
   
  elem: "#dataTree2",
  url: "../../../json/case/dataTree2.json",
  dataFormat: "list",  //配置data的风格为list
  checkbar:true //开启复选框
});

json格式


{
   
   
"status":{
   
   "code":200,"message":"操作成功"},
"data": [
  {
   
   "id":"001","title": "湖南省","checkArr": "0","parentId": "0"},
  {
   
   "id":"002","title": "湖北省","checkArr": "0","parentId": "0"},
  {
   
   "id":"003","title": "广东省","checkArr": "0","parentId": "0"},
  {
   
   "id":"004","title": "浙江省","checkArr": "0","parentId": "0"},
  {
   
   "id":"005","title": "福建省","checkArr": "0","parentId": "0"},
  {
   
   "id":"001001","title": "长沙市","checkArr": "0","parentId": "001"},
  {
   
   "id":"001002","title": "株洲市","checkArr": "0","parentId": "001"},
  {
   
   "id":"001003","title": "湘潭市","checkArr": "0","parentId": "001"},
  {
   
   "id":"001004","title": "衡阳市","checkArr": "0","parentId": "001"},
  {
   
   "id":"001005","title": "郴州市","checkArr": "0","iconClass": "dtree-icon-caidan_xunzhang","parentId": "001"}
]
}

2.3 layui+list集合数据格式

dtree.render({
   
   
  elem: "#dataTree3",
  url: "../../../json/case/dataTree2.json",
  dataStyle: "layuiStyle",  //使用layui风格的数据格式
  dataFormat: "list",  //配置data的风格为list
  response:{
   
   message:"msg",statusCode:0},  //修改response中返回数据的定义
  checkbar:true //开启复选框
});

json格式

{
   
   
"code":0,
"msg":"操作成功",
"data": [
  {
   
   "id":"001","title": "湖南省","checkArr": "0","parentId": "0"},
  {
   
   "id":"002","title": "湖北省","checkArr": "0","parentId": "0"},
  {
   
   "id":"003","title": "广东省","checkArr": "0","parentId": "0"},
  {
   
   "id":"004","title": "浙江省","checkArr": "0","parentId": "0"},
  {
   
   "id":"005","title": "福建省","checkArr": "0","parentId": "0"},
  {
   
   "id":"001001","title": "长沙市","checkArr": "0","parentId": "001"},
  {
   
   "id":"001002","title": "株洲市","checkArr": "0","parentId": "001"},
  {
   
   "id":"001003","title": "湘潭市","checkArr": "0","parentId": "001"},
  {
   
   "id":"001004","title": "衡阳市","checkArr": "0","parentId": "001"},
  {
   
   "id":"001005","title": "郴州市","checkArr": "0","iconClass": "dtree-icon-caidan_xunzhang","parentId": "001"}
]
}

三 、代码实现

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<link rel="stylesheet" href="resourse/layui/css/layui.css" media="all">
<link rel="stylesheet" href="resourse/layui_ext/dtree/dtree.css">
 <link rel="stylesheet" href="resourse/layui_ext/dtree/font/dtreefont.css">
</head>
<body>
 <ul id="dataTree3" class="dtree" data-id="0" ></ul>
<script src="resourse/layui/layui.js"></script>
    <script>
        layui.extend({
   
   
            dtree:'resourse/layui_ext/dist/dtree'
        }).use([ 'dtree', 'laydate','jquery','layer','form' ], function() {
   
   
            var $=layui.jquery;
            var table = layui.table;
            var form=layui.form;
            var dtree=layui.dtree;
            var laydate = layui.laydate;
            //初始化树-基本数据格式
            <!--
            var DemoTree = dtree.render({
   
   
                  elem: "#demoTree",
                  url: "resourse/layui_ext/json/case/asyncTree1.json" ,// 使用url加载(可与data加载同时存在)
                });
            -->
                //list类型
               <!--
               dtree.render({
   
   
                      elem: "#dataTree2",
                      url: "resourse/layui_ext/json/case/asyncTree2.json",
                      dataFormat: "list",  //配置data的风格为list
                      checkbar:true //开启复选框
                    });
                -->
                //layui+list集合数据格式
                dtree.render({
   
   
                      elem: "#dataTree3",
                      url: "resourse/layui_ext/json/case/asyncTree3.json",
                      dataStyle: "layuiStyle",  //使用layui风格的数据格式
                      dataFormat: "list",  //配置data的风格为list
                      response:{
   
   message:"msg",statusCode:0},  //修改response中返回数据的定义
                      checkbar:true //开启复选框
                    });
        });
    </script>
</body>
</html>

四、Dtree的事件监听

4.1 图标监听

 dtree.on("changeTree('dataTree2')" ,function(obj){
   
   
                  console.log(obj.param); // 点击当前节点传递的参数
                  console.log(obj.dom); // 当前节点的jquery对象
                  console.log(obj.show); // 节点展开为true,关闭为false
                });

在这里插入图片描述

4.2 节点监听(重点)

  dtree.on("node('dataTree2')" ,function(obj){
   
   
                      console.log(obj.param); // 点击当前节点传递的参数
                      console.log(obj.dom); // 当前节点的jquery对象
                      console.log(obj.childParams); // 当前节点的所有子节点参数
                      console.log(obj.parentParam); // 当前节点的父节点参数
                    });

image.png

4.3 节点双击事件

 dtree.on("nodedblclick('dataTree2')" ,function(obj){
   
   
                      console.log(obj.param); // 点击当前节点传递的参数
                      console.log(obj.dom); // 当前节点的jquery对象
                      console.log(obj.childParams); // 当前节点的所有子节点参数
                      console.log(obj.parentParam); // 当前节点的父节点参数
                    });

五、带有复选框的Dtree

image.png

image.png

      $("#requestValue").click(function () {
   
   
                        var params = dtree.getCheckbarNodesParam("dataTree2");  //获取复选框的值
                        layer.alert(JSON.stringify(params),{
   
   
                            title:'提交信息'
                    });
                    });

好了,今天的分享就到这里了哦
在这里插入图片描述

目录
相关文章
|
6月前
|
前端开发 JavaScript 容器
bootstrap-treeview树
bootstrap-treeview树
|
JSON Java 数据库
LayUI之动态树实现
LayUI之动态树实现
46 0
|
前端开发 JavaScript 数据安全/隐私保护
Layui之动态树(树形菜单)详解1
Layui之动态树(树形菜单)详解1
373 0
|
11月前
|
前端开发 数据格式
layui_02动态树
layui_02动态树
59 0
|
12月前
|
前端开发
基于antd实现一个Tree树形控件
基于antd实现一个Tree树形控件
188 0
|
JSON 前端开发 JavaScript
ztree实现一棵树
ztree实现一棵树
43 0
|
前端开发 Java 数据库
LayUI之动态树
LayUI之动态树
49 0
|
JSON 前端开发 JavaScript
Layui动态树详解
Layui动态树详解
70 0
|
XML 前端开发 数据库
Layui之动态树(树形菜单)详解2
Layui之动态树(树形菜单)详解2
83 0
|
JSON 前端开发 数据格式
EasyUI–树形控件tree详解
树形控件还是经常使用的,比如菜单、部门管理等涉及到有归属关系的功能经常在前端页面采用树形结构表示。 EasyUI对树形控件的封装非常的Nice,尤其是对复选框的支持简直是漂亮异常。本篇就最常用的菜单数为例演示EasyUI中tree的使用。 先看示意图:
613 0
EasyUI–树形控件tree详解