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 分钟前
JS中的链表(含leetcode例题)
javascript·leetcode·链表
方也_arkling38 分钟前
别名路径联想提示。@/统一文件路径的配置
前端·javascript
毕设源码-朱学姐40 分钟前
【开题答辩全过程】以 基于web教师继续教育系统的设计与实现为例,包含答辩的问题和答案
前端
qq_177767371 小时前
React Native鸿蒙跨平台剧集管理应用实现,包含主应用组件、剧集列表、分类筛选、搜索排序等功能模块
javascript·react native·react.js·交互·harmonyos
qq_177767371 小时前
React Native鸿蒙跨平台自定义复选框组件,通过样式数组实现选中/未选中状态的样式切换,使用链式调用替代样式数组,实现状态驱动的样式变化
javascript·react native·react.js·架构·ecmascript·harmonyos·媒体
web打印社区1 小时前
web-print-pdf:突破浏览器限制,实现专业级Web静默打印
前端·javascript·vue.js·electron·html
RFCEO1 小时前
前端编程 课程十三、:CSS核心基础1:CSS选择器
前端·css·css基础选择器详细教程·css类选择器使用方法·css类选择器命名规范·css后代选择器·精准选中嵌套元素
烬头88212 小时前
React Native鸿蒙跨平台采用了函数式组件的形式,通过 props 接收分类数据,使用 TouchableOpacity实现了点击交互效果
javascript·react native·react.js·ecmascript·交互·harmonyos
Amumu121382 小时前
Vuex介绍
前端·javascript·vue.js
We་ct2 小时前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript