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 UI Cascader 懒加载造成已选列表丢失的问题解决方案 -> 正文阅读

[JavaScript知识库]Element UI Cascader 懒加载造成已选列表丢失的问题解决方案

背景

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

  • 懒加载前
    懒加载前

  • 懒加载后
    懒加载后

解决方法

  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;
    });
  },
},
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-05-11 16:21:48  更:2022-05-11 16:22:51 
 
开发: 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:07:46-

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