经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 移动开发 » 微信小程序 » 查看文章
微信小程序仿今日头条导航栏滚动解析
来源:jb51  时间:2019/8/21 9:16:45  对本文有异议

项目需要,做一个和今日头条一样的导航栏,可以横行滚动,幸好再weui里面看到了类似的例子

地址:https://weui.shanliwawa.top/demo/js4.html,使用iscroll-lite.j实现,weui自己封装了一层,vue中实现代码:

  1. <div id="tab-tip" class="container">
  2. <div id="tagnav" class="weui-navigator weui-navigator-wrapper" style="touch-action: none;padding-left:5px">
  3. <ul class="weui-navigator-list first_nav">
  4. <li class v-for="group in groupList">
  5. <a href="javascript:;" rel="external nofollow" :groupId="group.id" @click="loadData(group.id)">{{group.name}}</a>
  6. </li>
  7. </ul>
  8. </div>
  9. </div> 初始化:
  10. mounted() {
  11.   setTimeout(function() {
  12.   TagNav("#tagnav", {
  13.   type: "scrollToNext",
  14.   curClassName: "weui-state-active",
  15.   index: 0
  16.   });
  17.   $(".first_nav")
  18.   .children(":first")
  19.   .find("a")
  20.   .addClass("first_border_circle");
  21.   $(".first_nav")
  22.   .children(":last")
  23.   .find("a")
  24.   .addClass("end_border_circle");
  25.   }, 0);
  26. },

注意:引入weui的css,class="container"这个一定要有,不然出现定位出现问题。

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

当然做这个项目的时候出现了一个问题,安卓手机第一次进入页面,非导航栏滑动的时候敏感,导致本来是滑动,触发了click事件,导致跳转

通过查找了许多资料,因为iscroll-lite默认事件touchend等绑定再window上,不是绑定再我们滚动的元素(上面例子:id="tagnav"的div),导致

点击其他的区域触发了click事件,幸好看到它有配置项:bindToWrapper,把这个值设定为true解决

因为weui重新封装了,所以找到,添加:bindToWrapper: true即可解决

  1. self.iScroll = new IScroll(self.el, {
  2. scrollX: true,
  3. scrollY: false,
  4. click: true,
  5. bindToWrapper: true//防止touchend等事件绑定到window,导致滑动敏感触发
  6. });

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号