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>
相关推荐
子兮曰5 小时前
async/await高级模式:async迭代器、错误边界与并发控制
前端·javascript·github
恋猫de小郭5 小时前
2026 Flutter VS React Native ,同时在 AI 时代 VS Native 开发,你没见过的版本
android·前端·flutter
GIS之路7 小时前
ArcGIS Pro 中的 Notebooks 入门
前端
IT_陈寒8 小时前
React状态管理终极对决:Redux vs Context API谁更胜一筹?
前端·人工智能·后端
Kagol9 小时前
TinyVue 支持 Skills 啦!现在你可以让 AI 使用 TinyVue 组件搭建项目
前端·agent·ai编程
柳杉9 小时前
从零打造 AI 全球趋势监测大屏
前端·javascript·aigc
simple_lau9 小时前
Cursor配置MasterGo MCP:一键读取设计稿生成高还原度前端代码
前端·javascript·vue.js
睡不着先生9 小时前
如何设计一个真正可扩展的表单生成器?
前端·javascript·vue.js
天蓝色的鱼鱼9 小时前
模块化与组件化:90%的前端开发者都没搞懂的本质区别
前端·架构·代码规范
明君879979 小时前
Flutter 如何给图片添加多行文字水印
前端·flutter