uniapp+vue+微信小程序实现侧边导航

效果:开始时图片一半隐藏, 手指划入侧边图片缓慢移出,划出缓慢移入隐藏

事件:

|--------------|----------|
| @touchstart | 手指触摸开始 |
| @touchmove | 手指触摸后移动 |
| @touchend | 手指离开 |
| @touchcancel | 被打断(来电等) |
| @tab | 立即离开 |

页面结构:

html 复制代码
<view class="maxBox">
        <view
            class="sideBox"
            :class="{ show: isTouching }"
            @touchstart="onTouchStart"
            @touchmove="onTouchMove"
            @touchend="onTouchEnd"
        >
            <view class="sideButton">
                <!-- 按钮的内容,可以是图片或文字 -->

            </view>
        </view>

</view>

逻辑:

javascript 复制代码
const startX = ref(0) // 记录触摸起始位置
const isTouching = ref(false) // 控制按钮显示状态


// 触摸开始事件
const onTouchStart = (event) => {
    // console.log("触摸开始事件", event)
    startX.value = event.touches[0].pageX;
    isTouching.value = true;
}

// 触摸移动事件
const onTouchMove = (event) => {
    // console.log("触摸移动事件", event)
    const moveX = event.touches[0].pageX;
    if (startX.value - moveX > 20) {
        isTouching.value = true;
    }
}
// 触摸结束事件
const onTouchEnd = (event) => {
    // console.log("触摸结束事件", event)
    setTimeout(() => {
        isTouching.value = false;
    }, 1500);//这里设置手指离开多久后重置
}

样式:

css 复制代码
.maxBox{
    min-height: 100vh;
    box-sizing: border-box;
    position: relative;
}

.sideBox {
        position: fixed;
        right: -50rpx; /* 半隐藏 */
        top: 50%;
        transform: translateY(-50%);
        width: 100rpx;
        height: 100rpx;
        transition: right 0.3s ease;
        z-index: 999;
}
.sideBox.show {
        right: 0; /* 全展示 */
}
相关推荐
HappyAcmen22 分钟前
关于微信小程序的面试题及其解析
微信小程序·小程序·notepad++
乔冠宇25 分钟前
微信小程序修改个人信息头像(uniapp开发)
微信小程序·小程序·uni-app
lvbb662 小时前
微信小程序-路线规划功能
微信小程序·小程序·notepad++
爱上大树的小猪4 小时前
微信小程序模仿快播标签云滚动特效
微信小程序·小程序
一个处女座的程序猿O(∩_∩)O4 小时前
Uniapp 开发中遇到的坑与注意事项:全面指南
uni-app
Elena_Lucky_baby4 小时前
uniapp 网络请求封装(uni.request 与 uView-Plus)
uni-app
计算机-秋大田5 小时前
基于Spring Boot的兴顺物流管理系统设计与实现(LW+源码+讲解)
java·vue.js·spring boot·后端·spring·课程设计
禾苗种树5 小时前
在 Vue 3 中使用 ECharts 制作多 Y 轴折线图时,若希望 **Y 轴颜色自动匹配折线颜色**且无需手动干预,可以通过以下步骤实现:
前端·vue.js·echarts
小盼江7 小时前
水果生鲜农产品推荐系统 协同过滤余弦函数推荐水果生鲜农产品 Springboot Vue Element-UI前后端分离 代码+开发文档+视频教程
vue.js·spring boot·ui
初遇你时动了情8 小时前
react module.scss 避免全局冲突类似vue中scoped
vue.js·react.js·scss