• element-ui el-cascader级联选择器设置指定层级不能选中


    有时候用element-ui el-cascader级联选择器添加分类时会遇到最多添加几级的限定.看了文档,只要给需要禁止选择的选项添加disabled属性就可以.但是使用一层一层循环遍历数据感觉很麻烦,自己写了个遍历的方法,纪录下,方便以后使用

    贴代码
    cascader.vue<template>
      <el-dialog
        title="添加分类"
        :visible.sync="dialogVisible"
        width="500px">
        <div class="role_contanier">
          <el-form label-width="80px" :model="typeInfo">
            <el-form-item label="分类名称">
              <el-input v-model="typeInfo.name"></el-input>
            </el-form-item>
            <el-form-item label="分类组">
              <el-cascader
                v-model="typeInfo.group"
                :options="typeOptions"
                :props="props"
                @change="handleChange">
              </el-cascader>
            </el-form-item>
            <el-form-item>
              <el-button type="primary" @click="submitForm">添加</el-button>
            </el-form-item>
          </el-form>
        </div>
        <span slot="footer" class="dialog-footer">
          <el-button @click="dialogVisible = false">取 消</el-button>
          <el-button type="primary" @click="dialogVisible = false">确 定</el-button>
        </span>
      </el-dialog>
    </template>
      
      <script>
      export default {
        props: {
          
        },
        data() {
          return {
            dialogVisible: false,
            typeInfo: {
              group: '',
              name: ''
            },
            typeOptions: [], // 分类层级选项
            props: {
              label: 'name', // 显示的选项
              value: 'id', // 选择的value值
              children: 'childs', // 子级属性名
              checkStrictly: true // 可以选择任意一级
            } // 指定层级属性
          }
        },
        created() {
          this.getTypeOptions()
        },
        mounted() {
         
        },
        methods: {
          // 获取分类级别
          getTypeOptions () {
            // 假设后台返回的数据 4级
            let resDate = [{
              id: 1,
              name: '食品',
              childs: [
                {id: 3, name: '进口食品', childs: [
                    {id: 5, name: '果干', childs: [{id: 7, name: '坚果',}]}, 
                    {id: 6, name: '面包'}
                  ]
                }, 
                {id: 4, name: '国内食品'}
              ]
              }, {id: 2, name: '清洁'}
            ]
            // 限制只能添加4级分类
            this.setDisable (1, resDate, 3)
            console.log(resDate)
            this.typeOptions = resDate
            this.dialogVisible = true
          },
    
          // 超过3级,不能选中,子级分类最多4级
          /**
           * count: 当前层级
           * data: 当前层级的数据
           * maxNum: 最多不能超过几级
          */
          setDisable (count, data, maxNum) {
            if (count > maxNum) { //最多几级就写几
              data.forEach(v => {
                v.disabled = true // 超过设定的最大级数,给这一集的数据添加disabled属性
              })
            } else {
              data.forEach(v => {
           v.count = count // 设置最外层数据的初始count
    if (v.childs && v.childs.length) { v.count++ this.setDisable(v.count, v.childs, maxNum) // 子级循环时把这一层数据的count传入 } }) } }, // 添加分类 submitForm () { }, handleChange (val) { console.log(val) } } } </script> <style> </style>

     效果图: 第4级,(坚果不能被选中,也就不能再往下添加分类)

  • 相关阅读:
    ReSharper 10.0.0.2 Ultimate 破解
    Image 和byte[]之间的转换
    IntelliJ IDEA 2016.1.3(64) license server 与汉化
    冒泡排序
    选择排序
    希尔排序
    插入排序
    redis学习笔记——Redis过期键的删除策略
    redis学习笔记——应用场景
    perl学习笔记——字符串和排序
  • 原文地址:https://www.cnblogs.com/steamed-twisted-roll/p/11744020.html
Copyright © 2020-2023  润新知