Element UI Cascader 懒加载造成已选列表丢失的问题解决方案

本文探讨了在使用级联器时遇到懒加载导致多级选项丢失的问题,提供了解决方案,即在级联器初始化时预加载已知的已选列表,确保数据完整。通过创建Cascador选项的方法和实例代码展示了如何在获取API数据后回显已选选项。

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

背景

某些情况下使用级联器时需要将已有的数据加载到级联器选择列表中,此时使用懒加载会使多级选项丢失,如图:

  • 懒加载前
    懒加载前

  • 懒加载后
    懒加载后

解决方法

  1. 初始化级联器选项(options)时,将已选列表加入选项。此方法仅限于已选列表数据均为最后一层的情况。否则也会触发懒加载造成数据丢失。
// Mixin 文件
// Mixins.js
export const Mixins = {
  data() {
    return {};
  },
  methods: {
    /**
     * 通过路径字符串列表生成级联器选项
     * @param origin 原始路径字符串列表
     * @returns {({children: *, label: *, value: *}|{label: *, value: *})[]}
     */
    createCascadorOptionsFromArray(origin) {
      let container = {};
      origin.map(path => {
        this.genPathTier(container, path.split('/'));
      })
      return Object.entries(container).map(
        ([key, val]) => this.createCascadorOptionsFromPathArray(key, val)
      );
    },
    /**
     * 将二维路径列表合并为树形结构
     * 例:['parent/child_st', 'parent/child_nd'] => [['parent', 'child_st'], ['parent', 'child_nd']] => {'parent': ['child_st', 'child_nd']}
     * @param container 容器,用以存放树形结构数据
     * @param pathArray 分离路径字符串得到的路径列表
     */
    genPathTier(container, pathArray) {
      if (pathArray.length > 1) {
        let parent = pathArray.shift();
        if (!container[parent]) {
          container[parent] = {};
        }
        this.genPathTier(container[parent], pathArray);
      } else {
        container[pathArray.shift()] = [];
      }
    },
    /**
     * 通过生成的路径树形结构数据获得级联器选项
     * @param cur 当前路径
     * @param childrenTier 当前路径的子级
     * @returns {{children: ({children: *, label: *, value: *}|{label: *, value: *})[], label, value}|{label, value}}
     */
    createCascadorOptionsFromPathArray(cur, childrenTier) {
      if (Object.keys(childrenTier).length) {
        return {
          value: cur, label: cur,
          children: Object.entries(childrenTier).map(
            ([key, val]) => this.createCascadorOptionsFromPathArray(key, val)
          )
        };
      } else {
        return {value: cur, label: cur}
      }
    }
  },
}
import {Mixins} from "./Mixins";
mixins: [Mixins],
methods: {
	genCascaderOptions(){
		CusApi.getPathTree().then(res => {
			// 通过 API 获取第一层并与已选列表一起传入自定义方法生成级联器选项
			this.PathCascaderOptions = this.createCascadorOptionsFromArray(
		        [...res.data.TreeResponse, ...this.formData.path || []]
		    );
		})
	}
}
  1. 懒加载前保存已选列表,懒加载后重新渲染。
gitbasePathCascaderProps: {
  lazy: true,
  lazyLoad: async (node, resolve) => {
    const {path} = node;
    // 懒加载前保存已选列表,用以加载后重新回显。
    let originSelectPath = [...this.formData.path];
    // 子级节点有值则跳过请求。
    if ((node.children || []).length) {
      resolve();
    } else {
      await CusApi.getPathTree().then(res => {
          // 若请求失败或已有子级,则不进行任何刷新。
          if (res.status === 200) {
            // 通过调用resolve将子节点数据返回,通知组件数据加载完成
            resolve(res.data.Response.map(path => {
              return {value: path, label: path, children: []};
            }));
          } else {
            resolve();
          }
        });
    }
    // 重新回显已选列表,必须在下一次渲染后执行,否则数据的更新会在渲染前,导致级联器无法成功监听数据变动。
    this.$nextTick(() => {
      // 一定要将级联器数据置空,否则可能不会触发重载。
      this.formData.path = [];
      this.formData.path = originSelectPath;
    });
  },
},
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱吃芒果的芬里尔狼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值