web前端之element级联选择器的那些事、获取label的值、getCheckedNodes、cascader、ref


动态加载时获取value和label的值

前言

1、使用ref的getCheckedNodes方法获取label的值,change事件只传递value值;
2、回显自动处理,无需手动干预,设置好接口即可。


html

html 复制代码
<el-cascader ref="refCascader" v-model="form.addressList" clearable :props="props" @change="changeCascader"></el-cascader>

JavaScript
data

javascript 复制代码
data() {
  return {
    form: {
      addressList: null
    },
    props: {
      // 设置为动态加载模式
      lazy: true,
      // 配置value字段
      value: 'id',
      // 配置label字段
      label: 'name',
      lazyLoad(node, resolve) {
        const { level, data: { id = '' } } = node;
        let mapList = (list) => list.map(item => {
          // 设置层级(表示到了第三级便不再显示展开图标,点击也不再有加载动画)
          item.leaf = level >= 2;

          return item;
        });

        getAddrTree({ parentId: id }).then(re => resolve(mapList(re.response)));
      }
    }
  }
}

methods

javascript 复制代码
changeCascader(event) {
  // 不明智的数据存储方式
  // let nodes = this.$refs.refCascader.getCheckedNodes()[0];
  // let [provinces, city, county] = nodes.pathLabels || [];
  // let [provincesId, cityId, countyId] = event || [];

  // this.form.provincesId = provincesId || '';
  // this.form.cityId = cityId || '';
  // this.form.countyId = countyId || '';
  // this.form.provinces = provinces || '';
  // this.form.city = city || '';
  // this.form.county = county || '';
  
  // 通用的数据存储方式
  let nodes = this.$refs.refCascader.getCheckedNodes()[0];
  this.form.ids = event.toString();
  this.form.label = nodes.pathLabels.toString();
}
相关推荐
thatway198927 分钟前
闲聊-关于AI终结者的警醒
前端
努力的小郑34 分钟前
突发!Claude Code 51万行源码全网裸奔:一场史诗级“开源”事故,国内大厂笑麻了
前端·后端·ai编程
七度黑光43 分钟前
用 openclaw 给故障复盘打分:质量审核自动化实践
运维·服务器·前端·数据库·自动化
HashTang1 小时前
Claude Code 源码中 REPL.tsx 深度解析:一个 5005 行 React 组件的架构启示
前端·后端·ai编程
wendycwb2 小时前
前端城市地址根据最后一级倒推,获取各层级id的方法
前端·vue.js·typescript
终端鹿2 小时前
Vue3 模板引用 (ref):操作 DOM 与子组件实例 从入门到精通
前端·javascript·vue.js
千寻girling2 小时前
不知道 Java 全栈 + AI 编程有没有搞头 ?
前端·人工智能·后端
小码哥_常3 小时前
Android开发:精准捕获应用的前后台行踪
前端
蜡台3 小时前
Vue 打包优化
前端·javascript·vue.js·vite·vue-cli
木斯佳3 小时前
前端八股文面经大全:快手前端一面 (2026-03-29)·面经深度解析
前端·宏任务·原型链·闭包