elementUI 级联选择器点击label文字部分选中及选中后收起菜单

        elementUI的级联选择器,在单选选择任意一级选项模式下,必须点击选项中的圆圈才能选中该项,且选中后菜单不会自动收起,得点击下拉框以外的代码才能收起。

         在实际开发中为了考虑用户操作的简便性,想实现点击label文字内容可以直接选中该项,且选中后收起菜单。

1 点击label文字内容选中选项

html:

<el-cascader
    ref="elcascader"
    :options="options"
    :props="{ checkStrictly: true }"
    v-model="value"
    clearable
    @visible-change="elCascaderOnClick"
    @expand-change="elCascaderOnClick">
</el-cascader>

ts: 

 elCascaderOnClick() {
    setTimeout(() => {
      document.querySelectorAll(".el-cascader-node__label").forEach((el) => {
        (el as any).onclick = function () {
          this.previousElementSibling.click();
        };
      });
    }, 100);
  }

2 选中后收起菜单

        监听改选择器绑定值的变化,当选中值改变时收起下拉菜单。

@Watch("value") 
onValueChange() {
    if(this.$refs.elcascader){
        this.$refs.elcascader.dropDownVisible = false;
    }
}

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个使用ElementUI级联选择器实现多级选中的示例代码: ```html <template> <div> <el-cascader v-model="selectedOptions" :options="options" :props="props" @change="handleChange" ></el-cascader> </div> </template> <script> export default { data() { return { selectedOptions: [], // 选中的选项 options: [ { value: "beijing", label: "北京", children: [ { value: "haidian", label: "海淀区", children: [ { value: "wudaokou", label: "五道口", }, { value: "zhongguancun", label: "中关村", }, ], }, { value: "chaoyang", label: "朝阳区", children: [ { value: "guomao", label: "国贸", }, { value: "sanlitun", label: "三里屯", }, ], }, ], }, { value: "shanghai", label: "上海", children: [ { value: "pudong", label: "浦东新区", children: [ { value: "lujiazui", label: "陆家嘴", }, { value: "zhangjiang", label: "张江", }, ], }, { value: "xuhui", label: "徐汇区", children: [ { value: "xujiahui", label: "徐家汇", }, ], }, ], }, ], props: { value: "value", label: "label", children: "children", }, }; }, methods: { handleChange(value) { console.log(value); // 输出选中的选项 }, }, }; </script> ``` 在上面的示例代码中,el-cascader组件是ElementUI级联选择器组件,v-model指令用于双向绑定选中的选项,options属性用于指定可选的选项,props属性用于指定选项的value、label和children属性名。@change事件用于监听选中的选项变化,handleChange方法用于处理选中的选项。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值