当前位置:首页 > VUE

vue实现长按删除

2026-03-08 22:22:21VUE

Vue 实现长按删除功能

长按删除功能在移动端或桌面端应用中较为常见,可以通过监听 touchstarttouchend(移动端)或 mousedownmouseup(桌面端)事件来实现。以下是具体的实现方法。

监听事件实现长按

在 Vue 中,可以通过自定义指令或直接在组件中绑定事件来实现长按功能。以下是一个基于自定义指令的实现方式:

// 注册全局指令
Vue.directive('longpress', {
  bind: function (el, binding) {
    let pressTimer = null;

    const start = (e) => {
      if (e.type === 'click' && e.button !== 0) return; // 确保是左键点击
      if (pressTimer === null) {
        pressTimer = setTimeout(() => {
          binding.value(); // 执行传入的函数
        }, 1000); // 长按时间为 1 秒
      }
    };

    const cancel = () => {
      if (pressTimer !== null) {
        clearTimeout(pressTimer);
        pressTimer = null;
      }
    };

    // 监听鼠标和触摸事件
    el.addEventListener('mousedown', start);
    el.addEventListener('touchstart', start);
    el.addEventListener('mouseup', cancel);
    el.addEventListener('mouseleave', cancel);
    el.addEventListener('touchend', cancel);
    el.addEventListener('touchcancel', cancel);
  },
});

在组件中使用指令

在模板中,可以通过 v-longpress 指令绑定一个方法,该方法会在长按触发时执行:

<template>
  <div>
    <button v-longpress="handleDelete">长按删除</button>
  </div>
</template>

<script>
export default {
  methods: {
    handleDelete() {
      console.log('长按触发删除');
      // 执行删除逻辑
    },
  },
};
</script>

直接绑定事件

如果不使用自定义指令,也可以在组件中直接绑定事件:

<template>
  <div>
    <button 
      @mousedown="startPress" 
      @mouseup="cancelPress"
      @touchstart="startPress" 
      @touchend="cancelPress"
    >
      长按删除
    </button>
  </div>
</template>

<script>
export default {
  data() {
    return {
      pressTimer: null,
    };
  },
  methods: {
    startPress() {
      this.pressTimer = setTimeout(() => {
        this.handleDelete();
      }, 1000);
    },
    cancelPress() {
      if (this.pressTimer) {
        clearTimeout(this.pressTimer);
        this.pressTimer = null;
      }
    },
    handleDelete() {
      console.log('长按触发删除');
      // 执行删除逻辑
    },
  },
};
</script>

优化用户体验

为了避免误触,可以添加视觉反馈,例如在长按时改变按钮样式:

<template>
  <button 
    v-longpress="handleDelete"
    :class="{ 'active': isPressing }"
  >
    长按删除
  </button>
</template>

<script>
export default {
  data() {
    return {
      isPressing: false,
    };
  },
  methods: {
    handleDelete() {
      console.log('长按触发删除');
      // 执行删除逻辑
    },
  },
};
</script>

<style>
.active {
  background-color: #ff0000;
  color: #ffffff;
}
</style>

移动端和桌面端兼容

如果需要同时支持移动端和桌面端,可以在指令或事件中同时监听 touchmouse 事件:

vue实现长按删除

// 在指令中同时监听 touch 和 mouse 事件
el.addEventListener('mousedown', start);
el.addEventListener('touchstart', start);
el.addEventListener('mouseup', cancel);
el.addEventListener('touchend', cancel);

注意事项

  1. 防抖处理:确保长按时间合理(通常为 1 秒左右),避免误触。
  2. 事件冒泡:在事件处理中注意阻止事件冒泡,避免触发父元素的事件。
  3. 性能优化:及时清除定时器,避免内存泄漏。

通过以上方法,可以在 Vue 中实现长按删除功能,并根据需求进行扩展和优化。

标签: vue
分享给朋友:

相关文章

vue手动实现弹窗

vue手动实现弹窗

实现弹窗组件的基本结构 在Vue中手动实现弹窗组件,需要创建一个独立的弹窗组件,并通过props控制其显示与隐藏。弹窗组件通常包含遮罩层、内容区域和关闭按钮。 <template>…

vue实现走势图

vue实现走势图

Vue 实现走势图的方法 使用 ECharts 库 ECharts 是一个强大的数据可视化库,支持多种图表类型,包括走势图(折线图)。在 Vue 项目中可以通过 vue-echarts 封装库或直接使…

vue实现报表

vue实现报表

vue实现报表的方法 使用Vue实现报表通常需要结合图表库或表格组件。以下是几种常见方法: 使用ECharts 安装ECharts库: npm install echarts vue-echart…

vue实现pie

vue实现pie

Vue 实现饼图 在 Vue 中实现饼图通常可以通过第三方图表库(如 ECharts、Chart.js 或 Highcharts)来完成。以下是使用 ECharts 和 Chart.js 的两种常见方…

vue滚动实现

vue滚动实现

Vue 滚动实现方法 使用原生滚动 在 Vue 中可以通过 ref 获取 DOM 元素,调用原生滚动方法实现滚动效果。适用于简单场景。 <template> <div ref=…

vue实现selectable

vue实现selectable

Vue 实现可选择的 Select 组件 在 Vue 中实现一个可选择的 Select 组件,可以通过以下几种方式: 使用原生 HTML select 元素 <template>…