码迷,mamicode.com
首页 > 其他好文 > 详细

zTree节点增删改

时间:2018-03-06 20:13:43      阅读:139      评论:0      收藏:0      [点我收藏+]

标签:conf   分享图片   css   cal   str   move   dom   AC   bsp   

 

  今天遇到一个需求是对zTree的节点进行增删改,经过查阅资料总结如下:

 

效果:

技术分享图片

 

 

完成增删改,要注意几个关键点:

 

  • 使用 编辑功能,必须设置 setting.edit 中的各个属性
  • 使用 编辑功能的事件回调函数,必须设置 setting.callback.beforeRemove / onRemove / beforeRename / onRename 等属性
  • zTree 不提供默认的增加按钮,如要实现需要利用自定义控件的方法 addHoverDom / removeHoverDom 
  • 我们利用 beforeEditName 来触发自定义的编辑操作

 

首先,我们来看看具体的配置信息(详细内容见代码中的注释):

<!DOCTYPE html>
<html>

    <head>
        <meta charset="UTF-8">
        <title>zTree测试</title>
        <link rel="stylesheet" type="text/css" href="css/demo.css" />
        <link rel="stylesheet" type="text/css" href="css/zTreeStyle/zTreeStyle.css" />
        <script src="js/jquery-1.4.4.min.js" type="text/javascript" charset="utf-8"></script>
        <script src="js/jquery.ztree.all.js" type="text/javascript" charset="utf-8"></script>
    </head>
    <script type="text/javascript">
    var zTree;
    var setting = {
            view:{
                addHoverDom:addHoverDom,
                removeHoverDom:removeHoverDom,
                selectedMulti:false
            },
            edit: {
                enable: true,
                editNameSelectAll:true,
                removeTitle:删除,
                renameTitle:重命名
            },
            data: {
                /* keep:{
                    parent:true,
                    leaf:true
                }, */
                simpleData: {
                    enable: true
                }
            },
            callback:{
                beforeRemove:beforeRemove,//点击删除时触发,用来提示用户是否确定删除
                beforeEditName: beforeEditName,//点击编辑时触发,用来判断该节点是否能编辑
                beforeRename:beforeRename,//编辑结束时触发,用来验证输入的数据是否符合要求
                onRemove:onRemove,//删除节点后触发,用户后台操作
                onRename:onRename,//编辑后触发,用于操作后台
                beforeDrag:beforeDrag,//用户禁止拖动节点
                onClick:clickNode//点击节点触发的事件
            }
        };
    var zNodes =[
                 { id:1, pId:0, name:"父节点 1", open:true},
                 { id:11, pId:1, name:"去百度",url:http://www.baidu.com,target:_blank},
                 { id:12, pId:1, name:"叶子节点 1-2"},
                 { id:13, pId:1, name:"叶子节点 1-3"},
                 { id:2, pId:0, name:"父节点 2", open:true},
                 { id:21, pId:2, name:"叶子节点 2-1"},
                 { id:22, pId:2, name:"叶子节点 2-2"},
                 { id:23, pId:2, name:"叶子节点 2-3"},
                 { id:3, pId:0, name:"父节点 3", open:true},
                 { id:31, pId:3, name:"叶子节点 3-1"},
                 { id:32, pId:3, name:"叶子节点 3-2"},
                 { id:33, pId:3, name:"叶子节点 3-3"}
             ];
    $(document).ready(function(){
        zTree = $.fn.zTree.init($("#tree"), setting, zNodes);
    });
    function beforeRemove(e,treeId,treeNode){
        return confirm("你确定要删除吗?");
    }
    function onRemove(e,treeId,treeNode){
        if(treeNode.isParent){
            var childNodes = zTree.removeChildNodes(treeNode);
            var paramsArray = new Array();
            for(var i = 0; i < childNodes.length; i++){
                paramsArray.push(childNodes[i].id);
            }
            alert("删除父节点的id为:"+treeNode.id+"\r\n他的孩子节点有:"+paramsArray.join(","));
            return;
        }
        alert("你点击要删除的节点的名称为:"+treeNode.name+"\r\n"+"节点id为:"+treeNode.id);
    }
    function beforeEditName(treeId,treeNode){
        /* if(treeNode.isParent){
            alert("不准编辑非叶子节点!");
            return false;
        } */
        return true;
    }
    function beforeRename(treeId,treeNode,newName,isCancel){
        if(newName.length < 3){
            alert("名称不能少于3个字符!");
            return false;
        }
        return true;
    }
    function onRename(e,treeId,treeNode,isCancel){
        alert("修改节点的id为:"+treeNode.id+"\n修改后的名称为:"+treeNode.name);
    }
    function clickNode(e,treeId,treeNode){
        if(treeNode.id == 11){
            location.href=treeNode.url;
        }else{
            alert("节点名称:"+treeNode.name+"\n节点id:"+treeNode.id);
        }
    }
    function beforeDrag(treeId,treeNodes){
        return false;
    }
    var newCount = 1;
    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(){
            //在这里向后台发送请求保存一个新建的叶子节点,父id为treeNode.id,让后将下面的100+newCount换成返回的id
            //zTree.addNodes(treeNode, {id:(100 + newCount), pId:treeNode.id, name:"新建节点" + (newCount++)});
            alert("开始添加节点")
            return false;
        });
    }
    function removeHoverDom(treeId,treeNode){
        $("#addBtn_"+treeNode.tId).unbind().remove();
    }
    </script>
<body>
    <ul id="tree" class="ztree"></ul>
</body>
</html>

 

zTree节点增删改

标签:conf   分享图片   css   cal   str   move   dom   AC   bsp   

原文地址:https://www.cnblogs.com/qlqwjy/p/8516207.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!