elementUI<cascader>组件中远程加载


** 如图,一级和二级是后端接口返回的,只需要把对应的key名改成value、label和children即可,第三级的内容是根据一级二级去请求接口返回的,所以需要注意以下问题**

  • 一级和二级确定都是由内容的,三级不确定,先要判断到了二级是否停止,用到组件中的leaf(true:代表停止,即没有下一级,没有右边的箭头,false代表下一级还有内容)
  • 第三级的选项
<el-cascader ref="cascader" :props="props"  clearable @change="handleChange" checkStrictly: true  />
  1. 首先:props="props"
  2. checkStrictly: true:代表可以在任意一级停止,不用选到最后一级
  3. handleChange:代表选择结束,到第二级或者第三级,默认参数是一个数组[选中的一级,二级, 三级]
  4. 最后就是懒加载
    首先在data中声明props: { lazy: true, lazyLoad: this.lazyLoad},
    然后在methods中定义lazyLoad方法,,代码如下
lazyLoad(node, resolve) {
    setTimeout(() => {
      this.getList(node, resolve)
    }, 200)
},
async getList(node, resolve) {
     let nodes = []
     const optionsList = []
     if (node.level === 0) {
       const res = await ResourceAdminAPI.queryListByDictClass({
         dictClass: 'resource'
       })
       let contentList = res.content || []
       this.typeOptionList = res.content || []
       contentList = contentList.map((item) => {
         return {
           value: item.dictType,
           label: item.dictName,
           leaf: false
         }
       })
       nodes = contentList
       resolve(nodes)
     } else if (node.level === 1) {
       nodes = this.typeOptionList.find((item) => item.dictName === node.label) .dictValueList || []
       nodes.map((item) => {
         this.getResourceNameList(node.value, item.dictValCode).then((res) => {
           item.value = item.dictValCode
           item.label = item.dictValName
           item.leaf = !res.length
           item.children = res.map((rc) => {
             return {
               value: rc.value,
               label: rc.label,
               leaf: true
             }
           })
         })
       })
       setTimeout(() => {
         resolve(nodes)
       }, 100)
     } else if (node.level === 2) {
       resolve(nodes)
     }
},
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值