AmazeUi Tree(树形结构) 应用小结


Posted in HTML / CSS onAugust 17, 2020

##这两天工作比较忙,不过还是要总结相关的坑,希望兄弟们要谨慎应用AmazeUI 里边自带的树形结构插件

##然后我简单说下我们公司前端应用:UI框架为AmazeUI(俗称妹子),交互框架为JQ。

##如果你公司对于树形结构这边要求不要求有点击事件,只是纯显示那么你可以继续向下看,如果要求树形结构支持勾选,支持拖拽等等...我建议你直接点击退出,去用Ztree吧

第一步:基本引入

<link rel="stylesheet" href="assets/css/amazeui.tree.min.css">
 
  <ul class="am-tree" id="tree">
                   <!--以下第一个li标签如果设计没有子级结构,可以屏蔽-->
                    <li class="am-tree-branch am-hide" data-template="treebranch">
                        <div class="am-tree-branch-header">
                            <button class="am-tree-branch-name">
                                <span class="am-tree-icon am-tree-icon-folder"></span>
                                <span class="am-tree-label"></span>
                            </button>
                        </div>
                        <ul class="am-tree-branch-children"></ul>
                        <div class="am-tree-loader"><span class="am-icon-spin am-icon-spinner"></span></div>
                    </li>
                    <li class="am-tree-item am-hide" data-template="treeitem">
                        <button class="am-tree-item-name">
                            <span class="am-tree-icon am-tree-icon-item"></span>
                            <span class="am-tree-label"></span>
                        </button>
                    </li>
                </ul>
<script src="assets/js/amazeui.tree.min.js"></script>

第二步:逻辑书写(可新建JS书写)

/*****粗加工后台数据(给单条数据增加了id,和pid,type,title),如果后台数据返回的直接带有层级结构的数据直接跳过这个步骤)
 *  for(i=0;i<odata.length;i++){
                    if(odata[i].level>=2){
                        //data[i].frameMenuStr
                        //截取倒数后两个"."后边的字符串/
                        let arr =["a","b","c","d","e","f","g","h","i"];
                        let str = odata[i].frameMenuStr;//当前数据ID
                        odata[i].id= arr[odata[i].level-1]+str.substring(str.lastIndexOf(".")+1);
                        let j =str.lastIndexOf(".");//当前数据父节点ID
                        odata[i].pid= arr[odata[i].level-2]+str.substring(str.lastIndexOf(".",j-1),str.lastIndexOf("."));
                        odata[i].title = odata[i].menuName;
                        odata[i].type = 'item';
                    }else{
                       odata[i].id = "a"+odata[i].frameMenuStr;
                       odata[i].title = odata[i].menuName;
                       odata[i].type = 'folder';
                       //odata[i].pid = "00000000"; 
                   }
                }
 * ********/
 /*******
 * 
 * data:灌入的数据(后台返回的值要为有id和pid)
 * dom 所要绑定的区域id
 * callbackfun:回调函数
 * 范例:
function bindTree(data,dom,callbackfun){
    /************核心应用:数组操作******************/
    let tree = data;
    var treeMaps = {};
    tree.forEach(function (value, index) {
       treeMaps[value.id] = value;
    })
    var data = [];
    tree.forEach(function (value, index) {
        var parent = treeMaps[value.pid]
        if (parent !== undefined) {
            if (parent.products === undefined) {
            parent.products = []
            }
            parent.products.push(value)
        } else {
            data.push(value);
        }
    })
    /***************以上这段代码是二次加工数据为的让之前没有层级结构的数据,加工成有层级结构的数据结构********************/
    dom.tree({
        dataSource:function(options, callback) {
            // 模拟异步加载
            let num = 0;//通过num值操作区分(这是个坑一定要用这种方法,不能用data||options.products)
            if(num==0){
                setTimeout(function() {
                  callback({data: data});//初始显示最高级别数据
                   num++;
                }, 400);
               
            }else{
                setTimeout(function() {
                  callback({data: options.products});//点击节点显示的数据
                }, 400);
            }
          },
        multiSelect: false,
        cacheItems: true,
        folderSelect: false,
    });
    dom.on('selected.tree.amui', function (event, data) {
        // do something with data: { selected: [array], target: [object] }
        //  console.log(data);
        // console.log(event);
         uuid = data.target.menuId;
         resData = data.target;
         if(callbackfun || typeof callbackfun != 'undefined' || callbackfun != undefined){
            return callbackfun(uuid);
          }
    });
    dom.tree("discloseAll");//这个函数暂时不起作用。
 }
 
 /**直接调用函数*/
 bindTree(odata,$("#tree"),function(){console.log("-------")});
 
 备注:
 
    //dom.tree("destroy");//数据更新我调用这个函数。但是一旦调用,直接所有dom结构都没有了,所以你要向之前绑定数据的地方重新灌入dom结构。
     /***********插件结构重新绘制***************/
    //  let str = "";
    //  str+='<li class="am-tree-branch am-hide" data-template="treebranch">';
    //     str+='<div class="am-tree-branch-header">';
    //         str+='<button class="am-tree-branch-name">';
    //         str+='<span class="am-tree-icon am-tree-icon-folder"></span>';
    //         str+='<span class="am-tree-label"></span>';
    //         str+='</button>';
    //     str+='</div>';
    //     str+='<ul class="am-tree-branch-children"></ul>';
    //     str+='<div class="am-tree-loader"><span class="am-icon-spin am-icon-spinner"></span></div>';
    //  str+='</li>';
    //  str+='<li class="am-tree-item am-hide" data-template="treeitem">';
    //     str+='<button class="am-tree-item-name">';
    //     str+='<span class="am-tree-icon am-tree-icon-item"></span>';
    //     str+='<span class="am-tree-label"></span>';
    //     str+='</button>';
    //  str+='</li>';
    //  dom.append(str);

##参考文章:

http://tech.yunyingxbs.com/article/detail/id/350.html
http://amazeui.github.io/tree/docs/demo.html

总结

到此这篇关于AmazeUi Tree(树形结构) 应用总结的文章就介绍到这了,更多相关AmazeUi Tree树形结构内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

HTML / CSS 相关文章推荐
css3闪亮进度条效果实现思路及代码
Apr 17 HTML / CSS
一款纯css3实现的响应式导航
Oct 31 HTML / CSS
详解CSS3实现响应式手风琴效果
Jun 10 HTML / CSS
CSS3只让背景图片旋转180度的实现示例
Mar 09 HTML / CSS
深入剖析webstorage[html5的本地数据处理]
Jul 11 HTML / CSS
HTML5 本地存储和内容按需加载的思路和方法
Apr 07 HTML / CSS
html5新增的属性和废除的属性简要概述
Feb 20 HTML / CSS
利用HTML5的新特点实现图片文件异步上传
May 29 HTML / CSS
从零实现一个自定义html5播放器的示例代码
Aug 01 HTML / CSS
canvas 如何绘制线段的实现方法
Jul 12 HTML / CSS
HTML5 实现图片上传预处理功能
Feb 06 HTML / CSS
html+css实现环绕倒影加载特效
Jul 07 HTML / CSS
AmazeUI 折叠面板的实现代码
Aug 17 #HTML / CSS
AmazeUI框架搭建的方法步骤(图文)
Aug 17 #HTML / CSS
AmazeUI 面板的实现示例
Aug 17 #HTML / CSS
AmazeUI 列表的实现示例
Aug 17 #HTML / CSS
详解如何使用rem或viewport进行移动端适配
Aug 14 #HTML / CSS
AmazeUI 导航条的实现示例
Aug 14 #HTML / CSS
AmazeUI导航的示例代码
Aug 14 #HTML / CSS
You might like
《五等分的花嫁》漫画完结!2020年10月第2期TV动画制作组换血!
2020/03/06 日漫
php对数组排序的简单实例
2013/12/25 PHP
ThinkPHP3.2.1图片验证码实现方法
2016/08/19 PHP
PHP让数组中有相同值的组成新的数组实例
2017/12/31 PHP
jQuery学习笔记 操作jQuery对象 属性处理
2012/09/19 Javascript
Javascript优化技巧之短路表达式详细介绍
2015/03/27 Javascript
在JavaScript中使用开平方根的sqrt()方法
2015/06/15 Javascript
JS显示日历和天气的方法
2016/03/01 Javascript
javascript表单处理具体实现代码(表单、链接、按钮)
2016/05/07 Javascript
Javascript打印局部页面实例
2016/06/21 Javascript
Vue.js实现拖放效果的实例
2016/09/30 Javascript
vue货币过滤器的实现方法
2017/04/01 Javascript
基于 Vue.js 2.0 酷炫自适应背景视频登录页面实现方式
2018/01/17 Javascript
JS实现不用中间变量temp 实现两个变量值得交换方法
2018/02/04 Javascript
详解webpack运行Babel教程
2018/06/13 Javascript
微信小程序之批量上传并压缩图片的实例代码
2018/07/05 Javascript
详解Vue源码之数据的代理访问
2018/12/11 Javascript
jQuery实现移动端下拉展现新的内容回弹动画
2020/06/24 jQuery
VUE和Antv G6实现在线拓扑图编辑操作
2020/10/28 Javascript
[00:34]拔城逐梦,热血永恒!2020(秋)完美世界城市挑战赛报名开启
2020/10/09 DOTA
Python自定义函数的创建、调用和函数的参数详解
2014/03/11 Python
python中numpy基础学习及进行数组和矢量计算
2017/02/12 Python
Python正则表达式分组概念与用法详解
2017/06/24 Python
Python3 chardet模块查看编码格式的例子
2019/08/14 Python
详细整理python 字符串(str)与列表(list)以及数组(array)之间的转换方法
2019/08/30 Python
window环境pip切换国内源(pip安装异常缓慢的问题)
2019/12/31 Python
Pyecharts 动态地图 geo()和map()的安装与用法详解
2020/03/25 Python
Django中ORM找出内容不为空的数据实例
2020/05/20 Python
css3一个简易的 LED 数字时钟实现方法
2020/01/15 HTML / CSS
英国领先的电子、技术和办公用品购物网站:Ebuyer
2018/04/04 全球购物
英国高街电视:High Street TV
2018/05/22 全球购物
房屋转让协议书
2014/04/11 职场文书
3分钟演讲稿
2014/04/30 职场文书
机关作风整顿个人剖析材料
2014/10/06 职场文书
安全生产标语大全
2014/10/06 职场文书
Redis 操作多个数据库的配置的方法实现
2022/03/23 Redis