Swipe横滑与SwipeItem自定义横滑相互影响

背景

vue项目,H5页面,使用vant的组件库轮播组件<Swipe>,UI交互要求,在每个SwipeItem中有内容,可自横滑,查看列表内容

核心代码

html 复制代码
<template>
  <Swipe
    class="my_swipe"
    :autoplay="3000"
    indicator-color="#9d9d9d"
    :stop-propagation="false"
    :show-indicators="false"
    @change="onChange"
  >
    <SwipeItem v-for="(item, index) in activeList" :key="item.activityId" class="swipe_item">
      <div class="activity-container">
        <StairNewUserBanner
          v-if="item.taskScene === SCENE.NEWUSER || item.taskScene === SCENE.REUNION"
          :banner-data="item"
          @jumpPage="jumpToActivePage"
        />
        <ProgressCard
          v-else
          :card-data="item"
          :card-index="index"
          @join="clickJoin(item, index)"
          @jumpPage="jumpToActivePage"
        />
      </div>
    </SwipeItem>
  </Swipe>
</template>
html 复制代码
<template>
  <div class="stair-new-user-banner-container">
    <div class="top" :style="topStyle" @click="jumpPage">
      <template v-if="!isCustomImg">
        <div class="title">
          <div class="left">{
  
  { topTitle }}</div>
          <div v-if="topTitle2" class="right">·</div>
          <div class="right">{
  
  { topTitle2 }}</div>
          <img class="arrow" src="https://www.baidu.com/" />
        </div>
        <div class="desc">
          <div v-if="showActivityRemindTime" class="remind-time">
            距结束
            <div v-if="activityRemindTime.days !== '00'" class="time-item">
              <div class="num">{
  
  { activityRemindTime.days }}</div>
              天
            </div>
            <div v-if="activityRemindTime.hours !== '00'" class="time-item">
              <div class="num">{
  
  { activityRemindTime.hours }}</div>
              小时
            </div>
            <div v-if="activityRemindTime.minutes !== '00' && activityRemindTime.days === '00'" class="time-item">
              <div class="num">{
  
  { activityRemindTime.minutes }}</div>
              分钟
            </div>
          </div>
          <div class="line"></div>
          <div>{
  
  { activityBizTypeDesc }}</div>
        </div>
      </template>
    </div>
    <div ref="bannerContent" class="content">
      <div class="crisp">
        <BannerSection
          v-for="(item, index) in sectionList"
          :key="index"
          :section-data="item"
          :static-data="staticData"
          :section-list="sectionList"
          :index="index"
        />
        <div class="bottom-bar">
          <div class="process-bar" :style="processBarStyle"></div>
        </div>
      </div>
    </div>
  </div>
</template>

问题描述

当想要滚动sectionList的内容时,SwipeItem跟着一起横滑

问题原因

sectionList列表的横滑事件冒泡了,影响到了轮播的横滑

解决方案

javascript 复制代码
  mounted() {
    this.handleTouchMove = (e) => {
      e.stopPropagation()
    }
    this.handleTouchStart = (e) => {
      e.stopPropagation()
    }
    this.$refs.bannerContent.addEventListener('touchmove', this.handleTouchMove)
    this.$refs.bannerContent.addEventListener('touchstart', this.handleTouchStart)
  },
  beforeDestroy() {
    this.$refs.bannerContent.removeEventListener('touchmove', this.handleTouchMove)
    this.$refs.bannerContent.removeEventListener('touchstart', this.handleTouchStart)
  }

fix

小程序的swiper组件和每个swiper-item中用<scroll-view class="content" scroll-x="{ {true}}"></scroll-view>包裹的横滑没有这个问题

相关推荐
技术小丁2 分钟前
使用 HTML +JavaScript 从零构建视频帧提取器
javascript·html·音视频
gyx_这个杀手不太冷静3 分钟前
Vue3 响应式系统探秘:watch 如何成为你的数据侦探
前端·vue.js·架构
晴殇i9 分钟前
🌐 CDN跨域原理深度解析:浏览器安全策略的智慧设计
前端·面试·程序员
漫谈网络21 分钟前
TypeScript 编译 ES6+ 语法到兼容的 JavaScript介绍
javascript·typescript·es6
Uyker35 分钟前
空间利用率提升90%!小程序侧边导航设计与高级交互实现
前端·微信小程序·小程序
bin915343 分钟前
DeepSeek 助力 Vue3 开发:打造丝滑的日历(Calendar),日历_天气预报日历示例(CalendarView01_18)
前端·javascript·vue.js·ecmascript·deepseek
江城开朗的豌豆44 分钟前
JavaScript篇:反柯里化:让函数'反悔'自己的特异功能,回归普通生活!
前端·javascript·面试
江城开朗的豌豆1 小时前
JavaScript篇:数字千分位格式化:从入门到花式炫技
前端·javascript·面试
十年砍柴---小火苗1 小时前
原生js操作元素类名(classList,classList.add...)
javascript·css·css3
henujolly2 小时前
网络资源缓存
前端