zoukankan      html  css  js  c++  java
  • 基于ztree的城市树形联动

    工作中有了需求,需要做三级联动里面的数据要作为树形的展示
    哈哈,那就找找有没有现成的,遗憾,费了不少功夫,因为想要基于layui的树形联动
    但是联动倒是有了,树形这个 贤心大神 还没有去做。
    所以我就找其他的一些插件,网上有jstree和ztree,我觉得ztree倒是挺适合我这次的需求
    作为抛砖引玉的代码
    我做了一个demo,效果是:实现父级和子级都可以被选中,展示到一个input中,父级和子级呈树形展示
    相当于是现在只是做了一个下拉单选框,哈哈,抛砖引玉,直接上代码:

    html:

    <!DOCTYPE html>
    <HTML>
    <HEAD>
        <TITLE> ZTREE DEMO - checkbox select menu</TITLE>
        <meta http-equiv="content-type" content="text/html; charset=UTF-8">
        <link rel="stylesheet" href="../../../css/demo.css" type="text/css">
        <link rel="stylesheet" href="../../../css/zTreeStyle/zTreeStyle.css" type="text/css">
        <script type="text/javascript" src="../../../js/jquery-1.4.4.min.js"></script>
        <script type="text/javascript" src="../../../js/jquery.ztree.core.js"></script>
        <script type="text/javascript" src="../../../js/jquery.ztree.excheck.js"></script>
        <!--   <script type="text/javascript" src="../../../js/jquery.ztree.exedit.js"></script>-->
        <SCRIPT type="text/javascript">
            <!--
            var setting = {
                view: {
                    showIcon: showIconForTree,
                    showLine:false
                },
                data: {
                    simpleData: {
                        enable: true
                    }
                },
                callback: {
                    // beforeClick: beforeClick,
                    onClick:onClick
                }
            };
            var zNodes =[
                {id:1, pId:0, name:"全部"},
                {id:2, pId:0, name:"天津"},
                {id:3, pId:0, name:"上海"},
                {id:6, pId:0, name:"重庆"},
                {id:4, pId:0, name:"河北省", open:true, nocheck:true},
                {id:41, pId:4, name:"石家庄"},
                {id:42, pId:4, name:"保定"},
                {id:43, pId:4, name:"邯郸"},
                {id:44, pId:4, name:"承德"},
                {id:5, pId:0, name:"广东省", open:true, nocheck:true},
                {id:51, pId:5, name:"广州"},
                {id:52, pId:5, name:"深圳"},
                {id:53, pId:5, name:"东莞"},
                {id:54, pId:5, name:"佛山"},
                {id:6, pId:0, name:"福建省", open:true, nocheck:true},
                {id:61, pId:6, name:"福州"},
                {id:62, pId:6, name:"厦门"},
                {id:63, pId:6, name:"泉州"},
                {id:64, pId:6, name:"三明"}
            ];
            function showIconForTree(treeId, treeNode) {
                return !treeNode.isParent;
            };
    
            function beforeClick(treeId, treeNode) {
                var check = (treeNode && !treeNode.isParent);
                if (!check) alert("只能选择城市...");
                return check;
            }
            function onClick(e, treeId, treeNode) {
                var zTree = $.fn.zTree.getZTreeObj("treeDemo"),
                    nodes = zTree.getSelectedNodes(),
                    v = "";
                nodes.sort(function compare(a,b){return a.id-b.id;});
                for (var i=0, l=nodes.length; i<l; i++) {
                    v += nodes[i].name + ",";
                }
                if (v.length > 0 ) v = v.substring(0, v.length-1);
                var cityObj = $("#citySel");
                cityObj.attr("value", v);
            }
    
            function showMenu() {
                var cityObj = $("#citySel");
                var cityOffset = $("#citySel").offset();
                $("#menuContent").css({left:cityOffset.left + "px", top:cityOffset.top + cityObj.outerHeight() + "px"}).slideDown("fast");
    
                $("body").bind("mousedown", onBodyDown);
            }
            function hideMenu() {
                $("#menuContent").fadeOut("fast");
                $("body").unbind("mousedown", onBodyDown);
            }
            function onBodyDown(event) {
                if (!(event.target.id == "menuBtn" || event.target.id == "citySel" || event.target.id == "menuContent" || $(event.target).parents("#menuContent").length>0)) {
                    hideMenu();
                }
            }
    
            $(document).ready(function(){
                $.fn.zTree.init($("#treeDemo"), setting, zNodes);
            });
            //-->
        </SCRIPT>
        <style type="text/css">
        </style>
    </HEAD>
    
    <BODY>
    <h1>带 checkbox 的多选下拉菜单  -- zTree</h1>
    <h6>[ 文件路径: super/select_menu_checkbox.html ]</h6>
    <div class="content_wrap">
        <div class="zTreeDemoBackground left">
            <ul class="list">
                <li class="title">&nbsp;&nbsp;<span class="highlight_red">勾选 checkbox 或者 点击节点 进行选择</span></li>
                <li class="title">&nbsp;&nbsp;Test: <input id="citySel" type="text" readonly value="" style="width:120px;" onclick="showMenu();" />
                </li>
            </ul>
        </div>
        <div class="right">
            <ul class="info">
                <li class="title"><h2>实现方法说明</h2>
                    <ul class="list">
                        <li>用 checkbox 也可以轻松实现多选的下拉菜单</li>
                        <li>此 Demo 主要用于 和 其他下拉菜单进行对比</li>
                    </ul>
                </li>
            </ul>
        </div>
    </div>
    
    <div id="menuContent" class="menuContent" style="display:none; position: absolute;">
        <ul id="treeDemo" class="ztree" style="margin-top:0; width:180px; height: 300px;"></ul>
    </div>
    </BODY>
    </HTML>

    js相关的文件就到ztree官网上下载吧

     zTree 是一个依靠 jQuery 实现的多功能 “树插件”。优异的性能、灵活的配置、多种功能的组合是 zTree 最大优点。

        zTree 是开源免费的软件(MIT 许可证)。

    zTree v3.0 将核心代码按照功能进行了分割,不需要的代码可以不用加载采用了 延迟加载 技术,上万节点轻松加载,即使在 IE6 下也能基本做到秒杀兼容 IE、FireFox、Chrome、Opera、Safari 等浏览器支持 JSON 数据支持静态 和 Ajax 异步加载节点数据支持任意更换皮肤 / 自定义图标(依靠css)支持极其灵活的 checkbox 或 radio 选择功能提供多种事件响应回调灵活的编辑(增/删/改/查)功能,可随意拖拽节点,还可以多节点拖拽哟在一个页面内可同时生成多个 Tree 实例简单的参数配置实现 灵活多变的功能

    最后我想说,其实文档里面讲的很详细,大家可以多看看,比较容易理解

  • 相关阅读:
    opendressinghash //use resize array
    ChainingHash
    Hash function
    stack && queue
    random_select
    counting sort
    master theorem
    各排序算法及其比较
    视图中添加主键的方法
    oracle表空间的扩展
  • 原文地址:https://www.cnblogs.com/hanlei525/p/9613017.html
Copyright © 2011-2022 走看看