uniapp 顶部通知 上滑隐藏

javascript 复制代码
<template>
  <view
    v-if="visible"
    class="top-notice-wrapper"
    :style="{ opacity: opacity, transform: `translateY(${translateY}px)` }"
    @touchstart="handleTouchStart"
    @touchmove="handleTouchMove"
    @touchend="handleTouchEnd"
  >
    <text class="notice-text">{{ message }}</text>
  </view>
</template>

<script setup lang="ts">
import { ref, onMounted } from 'vue'

const message = ref('这是顶部通知消息')
const opacity = ref(0)
const translateY = ref(-50)
const visible = ref(true) 

let startY = 0
const maxHideDistance = 50

onMounted(() => {
  setTimeout(() => {
    opacity.value = 1
    translateY.value = 0
  }, 50)
})

const handleTouchStart = (e: UniApp.TouchEvent) => {
  startY = e.touches[0].clientY
}

const handleTouchMove = (e: UniApp.TouchEvent) => {
  const currentY = e.touches[0].clientY
  let deltaY = currentY - startY

  if (deltaY < 0) {
    deltaY = Math.abs(deltaY)
    if (deltaY > maxHideDistance) deltaY = maxHideDistance

    translateY.value = -deltaY
    opacity.value = 1 - deltaY / maxHideDistance
  }
}

const handleTouchEnd = () => {
  if (translateY.value <= -maxHideDistance * 0.5) {
    opacity.value = 0
    translateY.value = -maxHideDistance
    setTimeout(() => {
      visible.value = false
    }, 300)
  } else {
    opacity.value = 1
    translateY.value = 0
  }
}
</script>

<style lang="scss" scoped>
.top-notice-wrapper {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  background-color: #ffd700;
  padding: 50rpx;
  text-align: center;
  z-index: 1000;
  transition: opacity 0.4s ease, transform 0.3s ease;
  font-size: 28rpx;
}

.notice-text {
  color: #000;
}
</style>
相关推荐
@大迁世界4 分钟前
TypeScript 的本质并非类型,而是信任
开发语言·前端·javascript·typescript·ecmascript
GIS之路13 分钟前
GDAL 实现矢量裁剪
前端·python·信息可视化
是一个Bug17 分钟前
后端开发者视角的前端开发面试题清单(50道)
前端
Amumu1213818 分钟前
React面向组件编程
开发语言·前端·javascript
持续升级打怪中40 分钟前
Vue3 中虚拟滚动与分页加载的实现原理与实践
前端·性能优化
GIS之路44 分钟前
GDAL 实现矢量合并
前端
hxjhnct1 小时前
React useContext的缺陷
前端·react.js·前端框架
冰暮流星1 小时前
javascript逻辑运算符
开发语言·javascript·ecmascript
前端 贾公子1 小时前
从入门到实践:前端 Monorepo 工程化实战(4)
前端
菩提小狗1 小时前
Sqlmap双击运行脚本,双击直接打开。
前端·笔记·安全·web安全