日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

微信小程序页面左右滑动事件+回到顶部

發布時間:2025/3/18 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 微信小程序页面左右滑动事件+回到顶部 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

微信小程序提供了頁面的上下滾動的事件,在頁面的js文件中,

page({
onPageScroll(e) {
console.log(e.scrollTop)
}
})
但是不是滑動事件,滑動事件需要自己加在view上,

<view bindtouchstart='touchStart' bindtouchend="touchEnd"></view>
如果不讓滑動事件冒泡的話.將bind改為catch就好了

<view catchtouchstart='touchStart' catchtouchend="touchEnd"></view>
在js文件中添加綁定的事件處理函數,在touchStart中,將觸摸開始獲取到的x和y值存儲到data里,例如touch.x和touch.y

touchStart(e) {
// console.log(e)
this.setData({
"touch.x": e.changedTouches[0].clientX,
"touch.y": e.changedTouches[0].clientY
});
}
在touchEnd中,也就是手指離開屏幕的事件處理函數中,首先獲取到此時的x和y值,

touchEnd(e) {
let x = e.changedTouches[0].clientX;
let y = e.changedTouches[0].clientY;
}
然后再寫一個判斷方向的簡單處理函數,建議將此方法寫在utils工具庫中,

/***

  • 判斷用戶滑動
  • 左滑還是右滑
    */
    const getTouchData = (endX, endY, startX, startY)=> {
    let turn = "";
    if (endX - startX > 50 && Math.abs(endY - startY) < 50) { //右滑
    turn = "right";
    } else if (endX - startX < -50 && Math.abs(endY - startY) < 50) { //左滑
    turn = "left";
    }
    return turn;
    }
    在此方法中,傳入四個參數,分別是手指離開的x和y值,分別為endX和endY,手指按下的x和y值,分別為startX和startY,判斷離開的x減去開始的x是否大于50px,也就是手指向左滑動超過50px,就是想左滑,如果小于-50則是向右滑,

但是如果此時用戶在向下滑或者向上滑的過程中也有向左滑和向右滑的偏移,此時判斷用戶有向左滑和向右滑就有點不準確了,所以如果滿足上述條件并且用戶上滑或者下滑的距離不超過50px才判定用戶確實是在左右滑動

有些用戶使用大拇指滑動的時候喜歡斜著滑,此時上下和左右都有滑動,至于該判斷用戶是向左右還是向上下,可以用斜率來判斷,或者引入touch.js,在這就不寫了,這個就作為一種很簡單輕量的解決辦法.

回到頂部

onPageScroll: function (e) { console.log(e.scrollTop) if (e.scrollTop>300) { this.setData({ showTop: false }) } else { this.setData({ showTop: true }) } }, goTop: function () { wx.pageScrollTo({ scrollTop: 0, duration: 300 }) }

轉載于:https://blog.51cto.com/13507333/2287275

總結

以上是生活随笔為你收集整理的微信小程序页面左右滑动事件+回到顶部的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。