elementUI select多级联动

需求:编辑时将值回显,若某一级修改,之后的全部清空

实现:通过watch监听值的改变,若改变,清空后一级的值,并调用方法请求下一级的option

问题:编辑赋值的时候也会触发watch,导致只能讲第一级的值回显,之后的被清空

解决:在select上添加回调方法visible-change,可以得到当前改变的值是编辑回显还是用户手动修改,通过一个变量控制,从而控制是否需要清空

代码:

dom: 

<el-form-item label="地址">
    <el-select v-model="form.province" placeholder="请选择省份" size="mini" value-key="id" @visible-change="handleChangeFlag">
        <el-option v-for="(item, index) in provinceOption" :key="index" :label="item.areaName" :value="item"></el-option>
    </el-select>
</el-form-item>
<el-form-item>
    <el-select v-model="form.city" placeholder="请选择城市" size="mini" value-key="id" @visible-change="handleChangeFlag">
        <el-option v-for="(item, index) in cityOption" :key="index" :label="item.areaName" :value="item"></el-option>
    </el-select>
</el-form-item>
<el-form-item>
    <el-select v-model="form.area" placeholder="请选择区县" size="mini" value-key="id" @visible-change="handleChangeFlag">
        <el-option v-for="(item, index) in countyOption" :key="index" :label="item.areaName" :value="item"></el-option>
    </el-select>
</el-form-item>

js:

添加变量:

changeFlag: false
watch: {
            'form.province'(e) {
                if( this.changeFlag ){
                    this.form.city = {}
                }
                if( e && e.id ){
                    this.handleGetCityList({ parentId: e.id })
                }
            },
            'form.city'(e) {
                if( this.changeFlag ){
                    this.form.area = {}
                }
                if( e && e.id ){
                    this.handleGetAreaList({ parentId: e.id })z
                }
            },
            'form.area'(e) {
                if( this.changeFlag ){
                    this.form.projectaddress = ''
                }
            }
        },
handleChangeFlag(type) {// select回调,判断当前下拉框是否展示
  this.changeFlag = type;
}

 

  • 1
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 11
    评论
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Neo 丶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值