关于vue轮播vue-seamless-scroll自动滚动插件复制出来的数据点击事件无效

47 篇文章 2 订阅
14 篇文章 1 订阅
本文讲述了在Vue2项目中使用vue-seamless-scroll时遇到的点击事件失效问题,通过事件委托方式解决了复制数据行的点击事件不生效,提供了解决方案和相关代码示例。
摘要由CSDN通过智能技术生成

前言

vue2 项目中使用vue-seamless-scroll,复制出来的数据点击无效,经过多方查找总结,终于解决问题了,写篇文章防止下次遇到

参考文章:
vue-seamless-scroll 点击click失效
【vue】vue-seamless-scroll点击事件失效
关于vue轮播vue-seamless-scroll自动滚动插件复制出来的数据点击事件无效
vue-seamless-scroll 滚动插件的使用及循环的列表点击事件不生效的解决方案

vue2项目中如何使用vue-seamless-scroll依赖,参考之前发布的文章:
【vue】 vue-seamless-scroll 无缝滚动依赖

解决

使用此组件,第二轮数据点击事件失效,采用事件委托解决,父元素绑定一个点击事件@click='clickup($event)',子元素添加JSON.stringify(item)即当前行数据

<template>
  <div
    class="maintable"
    @click="clickup($event)"
    v-if="datalist && datalist.length > 0"
  >
    <vue-seamless-scroll :data="datalist" :class-option="listOption">
      <div class="onebox" v-for="(item, index) in datalist" :key="index">
        <div class="name" :title="item.xm">{{ item.xm }}</div>
        <div class="phone">{{ item.enSjh }}</div>
        <div class="cardnumber">
          {{ item.enSfzh }}
          <!-- {{ item.cardnumber | jmsjh }} -->
        </div>
        <div class="record" :data-obj="JSON.stringify(item)">
          <!-- :data-obj="JSON.stringify(item)" 传递参数 -->
          追踪记录查看
        </div>
      </div>
    </vue-seamless-scroll>
  </div>
</template>

点击事件

clickup(e) {
     // 使仅点击按钮触发点击事件
     let row = JSON.parse(e.target.dataset.obj); // 传递参数
     console.log(row,"当前行数据")
 },

下班~

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

fruge365

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

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

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

打赏作者

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

抵扣说明:

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

余额充值