##这两天工作比较忙,不过还是要总结相关的坑,希望兄弟们要谨慎应用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树形结构内容请搜索Devmax以前的文章或继续浏览下面的相关文章,希望大家以后多多支持Devmax!

AmazeUi Tree(树形结构) 应用小结的更多相关文章

  1. android – Microsoft OData客户端Xamarin无法正常工作

    有谁知道MicrosoftOData客户端是否以及如何在XamarinDroid上运行?

  2. vue递归组件实现树形结构

    这篇文章主要为大家详细介绍了vue递归组件实现树形结构,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  3. LayUI—tree树形结构的使用解析

    这篇文章主要介绍了LayUI—tree树形结构的使用,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  4. PHP树形结构tree类用法示例

    这篇文章主要介绍了PHP树形结构tree类用法,结合实例形式分析了php无限分类树tree.class.php的定义及使用相关操作技巧,需要的朋友可以参考下

  5. jQuery treeview树形结构应用

    这篇文章主要为大家详细介绍了jQuery treeview树形结构应用,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  6. 如何将JavaScript将数组转为树形结构

    我们经常会碰到树形数据结构,比方组织层级、省市县或者者动植物分类等等数据,那么如何将JavaScript将数组转为树形结构,本文就详细的来了解一下

  7. 详解Java递归实现树形结构的两种方式

    在开发的过程中,很多业务场景需要一个树形结构的结果集进行前端展示,也可以理解为是一个无限父子结构,常见的有报表指标结构、菜单结构等,这篇文章主要介绍了Java递归实现树形结构的两种方式,需要的朋友可以参考下

  8. JS使用reduce()方法处理树形结构数据

    这篇文章主要介绍了JS使用reduce()方法处理树形结构数据,对树形结构数据感兴趣的同学,可以参考下

  9. JavaScript平铺数组转树形结构的实现示例

    本文主要介绍了JavaScript平铺数组转树形结构的实现示例,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. 浅谈JavaScript构造树形结构的一种高效算法

    这篇文章主要介绍了JavaScript构造树形结构的一种高效算法,对算法感兴趣的同学,可以参考下

随机推荐

  1. 微信小程序canvas实现水平、垂直居中效果

    这篇文章主要介绍了小程序中canvas实现水平、垂直居中效果,本文图文实例代码相结合给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下

  2. 使用HTML5做的导航条详细步骤

    这篇文章主要介绍了用HTML5做的导航条详细步骤,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  3. H5最强接口之canvas实现动态图形功能

    这篇文章主要介绍了H5最强接口之canvas实现动态图形功能,需要的朋友可以参考下

  4. Canvas高级路径操作之拖拽对象的实现

    这篇文章主要介绍了Canvas高级路径操作之拖拽对象的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  5. html5视频自动横过来自适应页面且点击播放功能的实现

    这篇文章主要介绍了h5视频自动横过来自适应页面且点击播放,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  6. 详解HTML5中的picture元素响应式处理图片

    这篇文章主要介绍了详解HTML5中的picture元素响应式处理图片,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  7. canvas像素点操作之视频绿幕抠图

    这篇文章主要介绍了canvas像素点操作之视频绿幕抠图的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  8. html5利用canvas实现颜色容差抠图功能

    这篇文章主要介绍了html5利用canvas实现颜色容差抠图功能,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

  9. canvas绘制视频封面的方法

    这篇文章主要介绍了canvas绘制视频封面的方法的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  10. HTML5拖拽功能实现的拼图游戏

    本文通过实例代码给大家介绍了HTML5拖拽功能实现的拼图游戏,代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧

返回
顶部