v-if应用:v-if为false的时候,Click事件不会被触发

在Vue2开发中,我遇到了根据用户行为来动态显示或隐藏删除图标的需求,而v-if指令正是为此设计的。然而,使用同一变量同时控制两个不同的行为会有预期之外的效果。

问题描述

假设我们有一个自定义组件common-input,其核心代码如下:

<script>
export default {
  name: 'common-input',
  props: {
    inputObject: {
      type: Object,
      default: () => {
        return {};
      }
    }
  },
  data() {
    return {
      isFocused: false,
      clearVisible: false
    };
  },

  watch: {
      inputObject: {
        immediate: true, //第一次就立即生效
        deep: true, // 数组及对象要深度watch
        handler(val) {
           this.updateClearStatus();
        }
      },
    },
    methods: {
   
    onFocus(){
      this.isFocused = true;
      this.updateClearStatus();
    },
    onBlur(){
      this.isFocused = false;
      this.updateClearStatus();
    },

    clickClearAction(){
      console.log('clear input info');
      this.inputObject.value = '';
    },
    updateClearStatus(){
      setTimeout(() => {
        if(this.inputObject.value.length > 0 && this.isFocused) {
        this.clearVisible = true;
      } else {
        this.clearVisible = false;
      }
      }, 200);
    }
}

在这个组件中,我们通过v-if="clearVisible"来控制一个清空输入框内容的图标的显示。当输入框有内容且获得焦点时,clearVisible会被设为true,图标显示;否则,图标隐藏。

遇到的问题

问题出现在用户点击清空图标时。点击清空图标应该触发clickClearAction方法,清空输入框内容。然而,由于点击图标会触发输入框的blur失焦事件,导致isFocused变为false,从而使clearVisible变为false,图标消失。结果是click事件不会被触发,输入框内容无法被清空。

这个可以理解为blur事件是先一步触发的,导致图标消失,进而无法触发其上面绑定的事件。

解决方案

为了避免blur事件导致图标消失并阻止click事件,我们需要调整逻辑。具体来说,我使用了不同的变量,然后还使用setTimeout来延迟v-if条件的变化,从而保证click事件能被正常触发。

以下是修改后的代码:

<template>
  <div>
    <input v-model="inputObject.value" class="main-input" type="tel" @focus="onFocus" @blur="onBlur" />
    <div class="icon-section" v-if="isClear" @click="clickClearAction">
      <i class="icon" />
    </div>
  </div>
</template>

<script>
export default {
  name: 'common-input',
  props: {
    inputObject: {
      type: Object,
      default: () => {
        return {};
      }
    }
  },
  data() {
    return {
      isFocused: false,
      isClear: false
    };
  },
  watch: {
    inputObject: {
      immediate: true,
      deep: true,
      handler(val) {
        this.updateClearStatus();
      }
    }
  },
  methods: {
    onFocus() {
      this.isFocused = true;
      this.updateClearStatus();
    },
    onBlur() {
      setTimeout(() => {
        this.isFocused = false;
        this.updateClearStatus();
      }, 200); // 延迟处理
    },
    clickClearAction() {
      console.log('clear input info');
      this.inputObject.value = '';
    },
    updateClearStatus() {
      if (this.inputObject.value.length > 0 && this.isFocused) {
        this.isClear = true;
      } else {
        this.isClear = false;
      }
    }
  }
};
</script>

在这个修改后的版本中,我们将blur事件的处理逻辑放入一个setTimeout中,延迟执行isFocused的状态更新。这确保了点击清空图标时,click事件能先被触发,再执行blur事件逻辑,从而避免图标过早消失的问题。

总结

在使用Vue2开发的时候,使用v-if来控制元素的显示和隐藏很常用。但是要注意的是,当v-if条件变化会影响到用户交互事件时,我们可能需要采取一些措施来确保事件的正常触发。

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值