溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

微信小程序如何實現(xiàn)今日頭條導(dǎo)航欄滾動效果

發(fā)布時間:2021-06-28 14:16:30 來源:億速云 閱讀:217 作者:小新 欄目:web開發(fā)

這篇文章給大家分享的是有關(guān)微信小程序如何實現(xiàn)今日頭條導(dǎo)航欄滾動效果的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

項目需要,做一個和今日頭條一樣的導(dǎo)航欄,可以橫行滾動,幸好再weui里面看到了類似的例子

地址:https://weui.shanliwawa.top/demo/js4.html,使用iscroll-lite.j實現(xiàn),weui自己封裝了一層,vue中實現(xiàn)代碼:

<div id="tab-tip" class="container">
  <div id="tagnav" class="weui-navigator weui-navigator-wrapper" >
   <ul class="weui-navigator-list first_nav">
    <li class v-for="group in groupList">
     <a href="javascript:;" rel="external nofollow" :groupId="group.id" @click="loadData(group.id)">{{group.name}}</a>
    </li>
   </ul>
  </div>
 </div> 初始化:
mounted() {
  setTimeout(function() {
  TagNav("#tagnav", {
  type: "scrollToNext",
  curClassName: "weui-state-active",
  index: 0
  });
  $(".first_nav")
  .children(":first")
  .find("a")
  .addClass("first_border_circle");
  $(".first_nav")
  .children(":last")
  .find("a")
  .addClass("end_border_circle");
  }, 0);
},

注意:引入weui的css,class="container"這個一定要有,不然出現(xiàn)定位出現(xiàn)問題。

setimeout等元素渲染完成再初始化。

當(dāng)然做這個項目的時候出現(xiàn)了一個問題,安卓手機第一次進(jìn)入頁面,非導(dǎo)航欄滑動的時候敏感,導(dǎo)致本來是滑動,觸發(fā)了click事件,導(dǎo)致跳轉(zhuǎn)

通過查找了許多資料,因為iscroll-lite默認(rèn)事件touchend等綁定再window上,不是綁定再我們滾動的元素(上面例子:id="tagnav"的div),導(dǎo)致

點擊其他的區(qū)域觸發(fā)了click事件,幸好看到它有配置項:bindToWrapper,把這個值設(shè)定為true解決

因為weui重新封裝了,所以找到,添加:bindToWrapper: true即可解決

self.iScroll = new IScroll(self.el, {
scrollX: true,
scrollY: false,
click: true,
bindToWrapper: true//防止touchend等事件綁定到window,導(dǎo)致滑動敏感觸發(fā)
});

感謝各位的閱讀!關(guān)于“微信小程序如何實現(xiàn)今日頭條導(dǎo)航欄滾動效果”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI