ElementUi级联选择器选择的数据渲染在div中

级联选择器选择的数据渲染在div中

需求:将选择的数据渲染在div中展示。
思路:当多选的时候是一个二维数组,单选时是一维数组,区分处理,不确定有多少层级,用递归实现,把拿到的数据放到数组里,然后处理成自己要的。``

<template>
  <div>
    <el-cascader
      v-model="value"
      :options="options"
      @change="handleChange"
      :props="props"
    ></el-cascader>
    <div>{{ this.deepCascader(this.options,this.value) }}</div>
  </div>
</template>
<script>
export default {
  data() {
    return {
      props: {
        // emitPath: false,
        multiple: true,
      },
      value: [],
      options: [
        {
          value: "zhinan",
          label: "指南",
          children: [
            {
              value: "shejiyuanze",
              label: "设计原则",
              children: [
                {
                  value: "yizhi",
                  label: "一致",
                },
                {
                  value: "fankui",
                  label: "反馈",
                },
                {
                  value: "xiaolv",
                  label: "效率",
                },
                {
                  value: "kekong",
                  label: "可控",
                },
              ],
            },
          ],
        },    
      ],
  },
methods: {
// 级联选择器多层级递归
deep(options, res, index, arr) {
  let data = options.find((val) => {
    return val.value === res[index];
  });
  arr.push(data.label);
  if (data.children && data.children.length > 0) {
    index++;
    // 有子级 递归
    deep(data.children, res, index, arr);
  }
},

//options级联选择器的结构
deepCascader(options, res) {
  if (res.length > 0) {
    //res拿到的是存放数据的数组
    // 如果是多选,存放的是二维数组
    // 判断数组里边是否是数组
    let isArray = res.every((items) => {
      return Array.isArray(items);
    });   
    let index = 0;
    //如果是二维数组,说明是多选
    if (isArray) {
      let twoArr = [];
      for (const val of res) {
        let arr = [];
        deep(options, val, index, arr);
        //item.separator  自定义渲染格式  xx/xx或xx-xx  .....
        twoArr.push(arr.join("/"));
      }
      //处理成div中要存放的形式 
      return twoArr.join(",");
    } else {
      let arr = [];
      deep(options, res, index, arr);
      return arr.join("/");
    }
  } else {
    return "";
  }
}
}
}
</script>

效果图
在这里插入图片描述

如果有更好的,希望小伙伴可以指正,本人需要多多学习。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值