级联选择器懒加载组件(element-ui级联选择器懒加载数据回显终极解决方案)

文章介绍了在element-ui的el-cascader组件懒加载模式下,数据回显复杂且耗费资源的问题。作者提供了一个名为lazy-select的自定义组件,该组件简化了回显数据的处理,只需要接口返回id和name对象数组。文章提供了组件的GitHub地址、安装方式、基本用法以及相关属性说明,帮助开发者实现多选和懒加载的级联选择器功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

lazy-select懒加载选择器组件

由于el-cascader组件的级联选择器采用懒加载方案的情况下数据回显非常复杂,一般需要将回显数据的相关树形结构全部加载,这种情况下一是非常复杂,二是需要调用多次接口造成很大的资源浪费,所以自行二次封装了懒加载的级联选择器组件。
在处理数据回显时,需要接口返回相关的id和name(可根据情况自定义)组成的对象数组即可,下边有代码实例
主要用于解决为了解决 element-ui级联选择器多选+懒加载回显实现不了的问题

git地址:https://github.com/BadMooncc/lazy-select

屏幕录制2023-02-02 13.09.49

安装

使用此组件前请确保安装了element-ui和 vue@2.x。

npm i lazy-select@1.0.2 -S
全局引入
<script>
import lazySelect from 'lazy-select'

Vue.use(lazySelect)
</script>
普通引入
<script>
import lazySelect from 'lazy-select'
export default {
  components: {
    lazySelect
  }
}
</script>

基本用法

<template>
  <lazy-select
    :props="{
      label: 'deptName'
    }"
    lazy
    node-key="id"
    :load="lazyLoad"
    v-model="demo">
  </lazy-select>
</template>
<script>
let id = 1
export default {
  name: 'lazy-select-demo',
  data() {
    return {
      demo: [ { id: 5, deptName: '部门5' }, { id: 2, deptName: '书院2' } ],
    }
  },
  methods: {
    lazyLoad(node, resolve) {
      setTimeout(() => {
        let  arr = []
        arr.push({ id: id, deptName: `部门${id}`, isLeaf: true })
        id += 1
        arr.push({ id: id, deptName: `书院${id}` })
        id += 1
        resolve(arr)
      }, 300);
    },
  }
}
</script>

Attributes

参数说明类型可选值默认值
empty-text内容为空的时候展示的文本String
node-key每个下拉节点选项用来作为唯一标识的属性String
props配置选项,具体看下表object
value(v-model)默认值array
lazy是否懒加载子节点,需与 load 方法结合使用booleanfalse
load加载子树数据的方法,仅当 lazy 属性为true 时生效function(node, resolve)
indent相邻级节点间的水平缩进,单位为像素number16
icon-class自定义树节点的图标string
accordion是否每次只打开一个同级树节点展开booleanfalse
check-on-click-node是否在点击节点的时候选中节点,默认值为 false,即只有在点击复选框时才会选中节点。booleanfalse

props

参数说明类型可选值默认值
label指定节点标签为节点对象的某个属性值string, function(data, node)
children指定子树为节点对象的某个属性值string
disabled指定节点选择框是否禁用为节点对象的某个属性值boolean, function(data, node)
isLeaf指定节点是否为叶子节点,仅在指定了 lazy 属性的情况下生效boolean, function(data, node)
### 解决Element UI级联选择器懒加载模式下多选数据无法正确回显 在处理Element UI的Cascader组件时,当启用懒加载并尝试实现多选功能时,可能会遇到已选项未能正确示的问题。这通常是因为懒加载机制仅在首次展开节点时才获取子节点的数据,在某些情况下可能导致缓存或状态同步方面出现问题。 为了确保懒加载下的多选能够正常工作,可以采取以下措施: 1. **确保唯一键配置** Cascader 组件中的 `props` 属性应当设置好唯一的 `value` 和 `label` 字段名,以及用于标识是否为叶子节点的字段名。对于懒加载来说,还需要提供一个函数来动态加载子项[^1]。 2. **优化数据结构** 对于懒加载数据应包含完整的路径信息以便后续匹配。这意味着服务器端响应不仅要有当前层级的信息,还应该携带父级ID或其他能构建完整树形结构的关键字。 3. **手动控制展开行为** 使用 `expand-trigger="click"` 来触发节点扩展,并通过监听事件如 `change` 或者自定义方法去主动请求未加载过的子节点数据。 4. **初始化默认值** 如果页面初次渲染就需要展示之前保存的选择,则应在组件挂载前准备好这些数据,并将其传递给cascader作为初始值。注意此时传入的是已经解析好的全量path数组形式而非仅仅是最后一层id。 5. **调试与验证** 利用浏览器开发者工具检查网络请求情况,确认每次点击都能成功发起新的异步调用来获取对应级别的菜单列表;同时也要关注console日志输出是否有异常报错影响到正常的交互逻辑。 ```javascript // 示例代码:Vue实例内部分片段 data() { return { options: [], // 存储所有可用选项 selectedOptions: [] // 用户选定的结果集 }; }, methods: { handleItemChange(value) { const lastValue = value[value.length - 1]; this.loadChildren(lastValue).then((children) => { let tempOption = [...this.options]; set(tempOption, `${value.join('.')}.children`, children); this.$set(this, 'options', tempOption); // 更新视图上的option tree }); }, loadChildren(id){ // 模拟异步接口调用过程... return new Promise(resolve=>{ setTimeout(()=>{ resolve([ { label:'child1', value:id+'-1' ,leaf:true }, { label:'child2', value:id+'-2', leaf:false } ]); },1000) }) } } ```
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值