<el-cascader
   :options="menudata"
   :props="defaultPropsa"
    v-model="val"
    clearable
    @change="menuchange"
 ></el-cascader>
data(){
   return{
      defaultPropsa: {
        //三级联动
        children: "children",
        label: "label",
        value: "id",
        checkStrictly: true
      },
      menudata: [], //三级联动data
      val: [],
      vals: [],
  }
}
 
 methods:{
 //三级联动
    async getmenudata() {
      const { data: res } = await this.$http.get("ruixing/chanPinJiaoFuAll"); //接口数据
      //  console.log(res.data);
      this.menudata = res.data;
    },
 //element组件里的 getCheckedNodes	获取选中的节点	
     getCascaderObj(val, opt) {
      return val.map(function(value, index, array) {
        for (var itm of opt) {
          if (itm.id == value) {
            opt = itm.children;
            return itm;
          }
        }
        return null;
      });
    },
  //三级联动change事件
    menuchange() {
      this.vals = this.getCascaderObj(this.val, this.menudata); //选中节点数据
     console.log(this.vals) 
    },
    }

效果

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

Logo

基于 Vue 的企业级 UI 组件库和中后台系统解决方案,为数万开发者服务。

更多推荐