首页前端开发HTMLAmazeUi Tree(树形结构) 应用小结

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

时间2024-01-25 06:05:50发布访客分类HTML浏览753
导读:收集整理的这篇文章主要介绍了AmazeUi Tree(树形结构 应用小结,觉得挺不错的,现在分享给大家,也给大家做个参考。 ##这两天工作比较忙,不过还是要总结相关的坑,希望兄弟们要谨慎应用amazeUI 里边自带的树形结构插件...
收集整理的这篇文章主要介绍了AmazeUi Tree(树形结构) 应用小结,觉得挺不错的,现在分享给大家,也给大家做个参考。

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

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

上一篇: wordpress添加Html5的表单验证re...下一篇:AmazeUI 折叠面板的实现代码猜你在找的html5相关文章 关于移动端h5开发相关内容总结2022-05-17html5教程-学表单的第二天2018-12-10html5教程-HTML5浏览器支持2018-12-10html5教程-HTML5智能表单2018-12-10html5教程-微信H5使用resLoader实现加载页效果2018-12-10html5教程-day01-初级-JS0-热身运动JS入门教程2018-12-10html5教程-html5shiv.js和respond.min.js2018-12-10html5教程-不同浏览器对于html5 audio标签和音频格式的兼容性2018-12-10html5教程-使用Html5实现手风琴案例2018-12-10html5教程-html5笔记2018-12-10 其他相关热搜词更多phpjavapython程序员load

若转载请注明出处: AmazeUi Tree(树形结构) 应用小结
本文地址: https://pptw.com/jishu/586205.html
AmazeUI 面板的实现示例 AmazeUI 折叠面板的实现代码

游客 回复需填写必要信息