IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> element Tree 懒加载,搜索请求后端 -> 正文阅读

[JavaScript知识库]element Tree 懒加载,搜索请求后端

tree自己提供的搜索,只能搜索加载好的数据,不符合我们这边的需求,这边换了一种思路,就是在搜索的时候,换成普通的 tree 当输入框是空的时候在换回之前懒加载的 tree,代码如下:

      <el-input placeholder="输入控制指令名称" size="mini" v-model="filterText" @input="filterNode"></el-input>
        <el-tree
              class="filter-tree"
              :props="propsOne"
              :load="loadNode"
              lazy
              node-key="key"
              highlight-current
              :expand-on-click-node="false"
              ref="tree"
              v-show="tree_tree_no_lazy == 1"
            > </el-tree>
            <!--       普通的数       -->
            <el-tree
              class="filter-tree"
              :props="propsOne"
              :data="treeData"
              :default-expand-all="true"
              highlight-current
              :expand-on-click-node="false"
              ref="tree_no_lazy"
              v-show="tree_tree_no_lazy == 2"
            ></el-tree>
data() {
    return {
      propsOne: {
        label: 'name',
        children: 'children',
        isLeaf: 'leaf'
      },
      treeData: [],
      tree_tree_no_lazy: 1,
      filterText: '',
    }
  },
methods: {
//这个根据自己业务改代码
async loadNode(node, resolve) {
      let arr = []
      if (node.level <= 1) {
        listTree({ 'name': node.data == undefined ? null : node.data.name, 'tier': node.level }).then(response => {
          response.data.map(function(value) {
            let Json = null
            if (node.level == 1) {
              let v = value.split('&')
              Json = { key: v[1] + '-' + v[0], 'subSystem': v[0], 'name': v[1], 'leaf': false }
            } else {
              Json = { key: value, 'name': value, 'leaf': false }
            }
            arr.push(Json)
          })
          resolve(arr)
        })
      } else {
        listLists({ orderType: node.data.name, subSystem: node.data.subSystem }).then(response => {
          response.data.map(function(value) {
            arr.push({
              'key': value.subSystem + '-' + value.orderType + '-' + value.orderName,
              'name': value.orderName,
              'id': value.id,
              'leaf': true
            })
          })
          resolve(arr)
        })
      }
    },
},
 /*当输入框变化时触发的方法*/
    filterNode() {
      let val = this.filterText.trim()
      if (!val) {
        this.tree_tree_no_lazy = 1
      } else {
        this.tree_tree_no_lazy = 2
        this.locNode_search()
      }
    },
    //搜索数据的方法
     locNode_search() {
      locNodeSearch({ search: this.filterText.trim() }).then(row => {
        if (row.code === 200) {
          let map = row.data
          let arr = []
          if (map != null) {
            for (let subSystemStr in map) {
              let Json = {}
              Json['key'] = subSystemStr
              Json['name'] = subSystemStr
              Json['leaf'] = false
              Json['children'] = []
              let subSystem = map[subSystemStr]
              for (let orderTypeStr in subSystem) {
                let Json2 = {}
                Json2['key'] = subSystemStr + '-' + orderTypeStr
                Json2['name'] = orderTypeStr
                Json2['subSystem'] = subSystemStr
                Json2['leaf'] = false
                Json2['children'] = []
                Json['children'].push(Json2)
                let orderType = subSystem[orderTypeStr]
                for (let i = 0; i < orderType.length; i++) {
                  let Json3 = {}
                  let key = subSystemStr + '-' + orderTypeStr + '-' + orderType[i].orderName
                  Json3['key'] = key
                  Json3['name'] = orderType[i].orderName
                  Json3['id'] = orderType[i].id
                  Json3['leaf'] = true
                  Json2['children'].push(Json3)
                }
              }
              arr.push(Json)
            }
          }
          this.treeData = arr
        }
      })
    },

后端

   /**
     * 搜索
     */
    @GetMapping("/locNodeSearch")
    public AjaxResult locNodeSearch(@RequestParam("search") String Search) {
        return AjaxResult.success(ykOrderUserListService.locNodeSearch(Search));
    }

 /**
     * 树结构搜索
     * @param search
     * @return
     */
    @Override
    public Map<String, Map<String, List<YkOrderUserList>>> locNodeSearch(String search) {
        Long userId = SecurityUtils.getUserId();
        YkOrderUserList youl = new YkOrderUserList();
        youl.setUserId(userId);
        youl.setOrderType(search);

        //查询 指令类别
        List<YkOrderUserList> orderTypes = this.selectYkOrderUserListList(youl);
        youl.setOrderType(null);
        youl.setOrderName(search);
        //查询 指令名称
        List<YkOrderUserList> orderNames = this.selectYkOrderUserListList(youl);
        orderTypes.addAll(orderNames);
        if (ObjectUtil.isEmpty(orderTypes)) return null;
        //获取第一层数据。
        Map<String, List<YkOrderUserList>> orderType_maps
                //过滤掉重复数据
                = orderTypes.stream().collect(Collectors.toMap(
                (e) -> e.getId(),
                (e) -> e,
                (e1, e2) -> e2,
                HashMap::new
        )).values()
                //分组
                .stream()
                .collect(Collectors.groupingBy(
                        (e) -> e.getSubSystem()
                ));
        //树结构
        Map<String, Map<String, List<YkOrderUserList>>> tree_map = new HashMap<>();
        //获取树结构
        orderType_maps.forEach((k, v) -> {
            //二级分组
            Map<String, List<YkOrderUserList>> orderType_map = v.stream().collect(Collectors.groupingBy((e) -> e.getOrderType()));
            tree_map.put(k, orderType_map);
        });
        return tree_map;
    }
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-05-10 11:48:02  更:2022-05-10 11:48:13 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 6:09:55-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码