element el-tree懒加载+搜索

思路

在el-tree 懒加载不兼容自带的查询,需要自己实现。

代码

  <el-input clearable @keyup.native.enter="handelSearch" size="small" v-model="search"> </el-input>
 <el-tree  :data="treeDataShow" ref=“tree” node-key="id"  lazy :load="loadNode"  />
 
 data() {
    return {
       search:'',//搜索参数
      treeData:[],//总数据,由于要前端自己实现搜索,所以需要参数保存所有数据
      treeDataShow :[],//当时不使用懒加载时,el-tree的显示数据
      chooseNode: {},//当前选中节点
      resolve:null,//保存load的resolve方法
    }
  },
  mounted() {
    this.$nextTick(() => {
      //调用loadData方法展开第二层
      let nodedata = this.chooseNode.childNodes[0]
      nodedata.expanded = true
      nodedata.loadData()
    })
  },
  methods: {
    loadNode(node, resolve) {
    if(node.level===0){
    	this.chooseNode = node//保存初始节点
    	this.resolve =resolve//保存resolve方法
    }
    },
    handelSearch(){
    this.$refs.tree.$data.store.lazy = !this.search//根据搜索参数判断是否开启懒加载
      if (this.search) {
      //需要自己实现搜索方法 调用接口/前端js实现
      //处理数据将对应的树形结构数据赋值给treeDataShow 
      } else {
        this.treeDataShow = []//清空原来的treeDataShow数据
        setTimeout(() => {
        //注意使用异步,否则 this.treeDataShow = [],会将你留下一行代码懒加载的数据一起清空
          this.loadNode(this.tree.chooseNode, this.tree.resolve)
        }, 50)
      }
    }
  }
  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
要实现 element plus el-tree 懒加载并默认展开第二层,可以使用 el-tree 的 lazy 属性和 default-expand-all 属性。具体实现步骤如下: 1. 设置 el-tree 的 lazy 属性为 true,表示开启懒加载。 2. 在 el-tree 的 data 属性中,只设置根节点和第一层节点的数据,其他节点的数据在需要时再通过 load 方法加载。 3. 设置 el-tree 的 default-expand-all 属性为 true,表示默认展开所有节点。 4. 使用 el-tree 的 node-click 事件来监听节点的点击操作,判断是否需要加载该节点的子节点数据。 下面是一个示例代码,实现了默认展开第二层并懒加载子节点数据的 el-tree: ``` <template> <el-tree :data="data" :lazy="true" :default-expand-all="true" @node-click="handleNodeClick" > </el-tree> </template> <script> export default { data() { return { data: [{ label: '根节点', id: 1, children: [{ label: '第一层节点1', id: 2, children: [] }, { label: '第一层节点2', id: 3, children: [] }] }] }; }, methods: { handleNodeClick(node) { // 判断是否需要加载子节点数据 if (node.level === 1 && node.childNodes.length === 0) { // 模拟异步加载数据 setTimeout(() => { node.loading = false; node.children = [{ label: '第二层节点1', id: 4, children: [] }, { label: '第二层节点2', id: 5, children: [] }]; }, 1000); node.loading = true; } } } } </script> ``` 在这个示例中,el-tree 的 data 属性只设置了根节点和第一层节点的数据,其他节点的数据将在需要时再加载。而在 el-tree 的事件处理中,我们监听了 node-click 事件,当用户点击某个节点时,判断该节点是否为第二层节点,并且该节点还没有加载过子节点数据,如果是,则通过 load 方法异步加载数据,并设置 loading 状态。待数据加载完成后,再将节点的 children 属性设置为新加载的子节点数据,同时将 loading 状态设置为 false,这样就完成了懒加载的操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值