ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

ElementUI 级联动态加载及回显

2021-03-10 08:35:38  阅读:319  来源: 互联网

标签:category 级联 回显 ElementUI res amp data id


转:

ElementUI 级联动态加载及回显

先看图,你是否也遇到这个需求?
ElementUI 级联动态加载及回显

如果你正在焦头烂额,无脑抓瞎,那么你来对地方了,因为我将给你一个简单易懂的实现方案。

我也在网上翻了无数页答案,也照着别人的代码和思路尝试了,事实上并不能解决我这个棘手的问题。

级联下拉选多选、懒加载、数据回显,尽管 ElementUI 已经很贴心,文档写的也很好。

前两个很容易就可以实现,可是唯独数据回显被遗忘了,似乎忘记了数据回显应该是级联选择器必备的功能,很遗憾,需要我们自己去实现。

根据文档我们可以很容易配置一个级联组件,并且级联选择器的值应该是一个二维数组。


然后配置cascaderProps数据如下

cascaderProps: {
  multiple: true,
  checkStrictly: true,
  lazy: true,
  lazyLoad: this.lazyLoad,
  value: "id",
  label: "name",
  leaf: "leaf"
}

如果照做了,那么恭喜你,已经实现了一半的需求了,不过你很快就会发现,编辑的时候级联选择器的数据是空的。

不过组件给我们提供了一个参数options,如果级联选择的模板是完整的,那就可以很容易回显这个数组,可是现在的选择模板是懒加载的,那么就需要根据updateForm.category 拼出一个备选模板就可以了。

问题的关键就在于options模板如何生成,这个问题困恼了我好几天,最后也是灵感加成,十分钟就撸完了。

先看一段代码,然后分析下思路。

 //编辑类目
    async updateBtnClick(node, data) {
      this.node = node.parent;
      this.updateForm.id = data.id;
      this.updateForm.name = data.name;
      this.updateForm.level = ["一级类目", "二级类目", "三级类目", "四级类目"][
        node.level - 1
      ];
      this.updateForm.parent_name = node.level > 1 ? node.parent.data.name : "";
      this.updateForm.category = data.category || [];
      // this.updateForm.category_name = data.category_name || [];
      this.category_array = Array.from(
        new Set(this.updateForm.category.join(",").split(","))
      );
      this.initOptions();
    },
    //初始化category
    async initOptions() {
      let req = {
        parent_id: 0,
        category_id: this.node.id || 0
      };
      let res = await this.$api.getFrontcategoryTemp(req);
      if (res.error_code == 0 && res.data && res.data.list) {
        this.cascaderOptions = await this.loadOptions(res.data.list || []);
        this.updateForm.visible = true;
      }
    },
    //递归加载子类目
    async loadOptions(category) {
      let array = [];
      for (let i = 0; i < category.length; i++) {
        if (
          category[i].child_count > 0 &&
          this.category_array.includes(category[i].id + "")
        ) {
          let req = {
            parent_id: category[i].id,
            category_id: this.node.id || 0
          };
          let res = await this.$api.getFrontcategoryTemp(req);
          if (res.error_code == 0 && res.data && res.data.list) {
            category[i].children = await this.loadOptions(res.data.list);
          }
        }
        array.push(category[i]);
      }
      return array;
    },

解决方案的思路:

1、将需要回显的数据二维数组平铺成一维数组并去重。

2、初始化备选项的一级下拉选。

3、遍历一级下拉选判断是否需要加载子类目。

4、递归遍历下拉选。

这个方案确实也是非常容易理解的,与我们手动点击加载子集类似。

最终的组件配置如下:


好了,希望你能搜到我这个方案,最好尽快搜到。

ElementUI 版本2.13.2。


再来更新一点,算是优化吧。

针对第一步

1、将需要回显的数据二维数组平铺成一维数组并去重。

可以做点优化,二维数组

[[1,10,101],[1,11,115],[2,20,201,2014]]
//可以去掉最后一位
[[1,10],[1,11],[2,20,201]]
//这样可以减少很多请求

减少不必要的资源开销

点击查看更多内容

转:

ElementUI 级联动态加载及回显

标签:category,级联,回显,ElementUI,res,amp,data,id
来源: https://www.cnblogs.com/wangtcc/p/14509318.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有