微信小程序仿今日头条导航栏滚动解析
程序员文章站
2024-02-04 10:53:58
项目需要,做一个和今日头条一样的导航栏,可以横行滚动,幸好再weui里面看到了类似的例子
地址:,使用iscroll-lite.j实现,weui自己封装了一层,vue中实...
项目需要,做一个和今日头条一样的导航栏,可以横行滚动,幸好再weui里面看到了类似的例子
地址:,使用iscroll-lite.j实现,weui自己封装了一层,vue中实现代码:
<div id="tab-tip" class="container"> <div id="tagnav" class="weui-navigator weui-navigator-wrapper" style="touch-action: none;padding-left:5px"> <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"这个一定要有,不然出现定位出现问题。
setimeout等元素渲染完成再初始化。
当然做这个项目的时候出现了一个问题,安卓手机第一次进入页面,非导航栏滑动的时候敏感,导致本来是滑动,触发了click事件,导致跳转
通过查找了许多资料,因为iscroll-lite默认事件touchend等绑定再window上,不是绑定再我们滚动的元素(上面例子:id="tagnav"的div),导致
点击其他的区域触发了click事件,幸好看到它有配置项:bindtowrapper,把这个值设定为true解决
因为weui重新封装了,所以找到,添加:bindtowrapper: true即可解决
self.iscroll = new iscroll(self.el, { scrollx: true, scrolly: false, click: true, bindtowrapper: true//防止touchend等事件绑定到window,导致滑动敏感触发 });
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。