zTree

【1】摺疊展開

<div class="box-tools pull-right">
    <button type="button" id="expandfalse" class="btn btn-box-tool" title="摺疊">
        <i class="fa fa-minus"></i>
    </button>
    <button type="button" id="expandtrue" class="btn btn-box-tool" title="展開">
        <i class="fa fa-plus"></i>
    </button>
</div>
var zTree = $.fn.zTree.init($("#bid_dept"), setting);
$('#expandfalse').click(function (e) {
        e.preventDefault();
        zTree.expandAll(false);
});        
$('#expandtrue').click(function (e) {
        e.preventDefault();
        zTree.expandAll(true);
 });

1)html:

<ul id="t_suptype" class="ztree"></ul>

2)js腳本:

$(function(){
    var setting = {
            view: {
                addHoverDom: addHoverDom,
                removeHoverDom: removeHoverDom,
                selectedMulti: false
            },
            data : {
                simpleData : {
                    enable : true,
                    idKey : "id",
                    pIdKey : "parent"
                }
            },
            async: {
                enable: true,
                url: "base/suptype/tree",
                autoParam: ["id", "t", "level=lv"],
                type: "get"
            },
            callback : {
                onClick : function(e, treeId, treeNode) {
                    //console.log(treeNode);
                    urlDetail = '/base/suptype/detail?id=' + encodeURIComponent(treeNode.id);
                    $('#supdetails').load(urlDetail);
                }
            } 
        };
        var zTree = $.fn.zTree.init($("#t_suptype"), setting);

             //下面的是設置了新增按鈕的和設置了高度的代碼
        function addHoverDom(treeId, treeNode) {        
            var sObj = $("#" + treeNode.tId + "_span");
            if (treeNode.editNameFlag || $("#addBtn_"+treeNode.tId).length>0) return;
            var addStr = "<span class='button add' id='addBtn_" + treeNode.tId
                + "' title='增長子項' onfocus='this.blur();'></span>";
            sObj.after(addStr);
            var btn = $("#addBtn_"+treeNode.tId);
            if (btn) btn.bind("click", function(){
                
                $('#modal-operate').modal('show');        
                var url = '/base/suptype/add?parent=' + encodeURIComponent(treeNode.id);
                $('#modal-operate-body').load(url);
            });
        };
        
        function removeHoverDom(treeId, treeNode) {
            $("#addBtn_"+treeNode.tId).unbind().remove();
        };    
        
        var windowHeight  = $(window).height();
        var mainheaderH = $('.main-header').outerHeight();      
        var contentheaderH     = $('.content-header').outerHeight();
        var boxorgheaderH = $('#boxheader').outerHeight();
        var deptlistH = windowHeight - mainheaderH - contentheaderH - boxorgheaderH - 30 - 3;

        $('#boxlist').slimScroll({
          height: deptlistH
          });
})

3)控制器

/**
 * yyh
 * 20180817
 * 控制器
 * @return
 */
@ResponseBody
@GetMapping("/tree")
@RequiresPermissions("base:suptype:suptype")
public String tree(){
    List<zTreeNode> suptypeList = suptypeService.getTreeAllSuptype();    
    return JSON.toJSONString(suptypeList);
}

4)映射文件

<select id="getTreeAllSuptype" resultType="com.tuodata.bid.common.domain.zTreeNode">
        select `id`,`parent`,`code`,`name`,`icon`,`t`,`isp`,`open`,`s`,`ls`,`f` from bid_suptype where f = 1
</select>

5)zTree工具類

package com.tuodata.bid.common.domain;
import java.io.Serializable;
//zTree工具類
public class zTreeNode implements Serializable {
    private static final long serialVersionUID = 1L;
    private String id;
    private String parent;
    private String name;
    private Boolean open;
    private Boolean isp;
    private String icon;
    private int t;
    private int s;
    //省略getter setter
    @Override
    public String toString() {
        return "zTreeNode [id=" + id + ", parent=" + parent + ", name=" + name + ", open=" + open + ", isp=" + isp
                + ", icon=" + icon + ", t=" + t + ", s=" + s + "]";
    }    
}

6)保存後鎖定到新增的節點

若是zTree中放了添加按鈕,這個就是保存成功以後回去頁面展開顯示新增的節點
/**
     * 保存
     */
    @ResponseBody
    @PostMapping("/save")
    @RequiresPermissions("base:suptype:add")
    public String save( SuptypeDO suptype, @RequestParam("code") String code,@RequestParam("name") String name){
        String uuid = UUID.randomUUID().toString().replace("-", "");
        suptype.setCode(code);
        suptype.setName(name);
        suptype.setId(uuid);
        suptype.setF(1);
        
        if(suptypeService.save(suptype)>0){
            zTreeNode node = new zTreeNode();
            node.setId(suptype.getId());
            node.setParent(suptype.getParent());
            node.setName(suptype.getName());            
            
            return JSON.toJSONString(node);
        }
        return JSON.toJSONString(R.error());
    }

【2】禁止獲取非文件夾的樹的值(觀察到複選框是暗色的)

check: {
    enable: true,
    chkboxType: { "Y" : "", "N" : "" }
}

【3】禁止獲取非文件夾的樹的值(觀察到複選框是暗色的)

(id, parent, code, name, icon, t, isp, open, s, ls, f)
parent:父節點
open:是否展開
1)樹實體的字段對應
2)sql腳本
3)界面查詢

【4】判斷有無選中節點

var t_sup = $.fn.zTree.getZTreeObj("t_sup");
var tnodes = t_sup.getCheckedNodes();
if (tnodes.length == 0) {
    toastr.warning("請選擇關聯的供應商分類");
    return;
}
相關文章
相關標籤/搜索