zoukankan      html  css  js  c++  java
  • 小程序自定义tabbar

    代码片段wechatide://minicode/IUoCyemJ7D3d

    GitHub: https://github.com/WozHuang/Miniprogram-Demo/tree/master/custom-tabbar

    在项目中要求用tabbar,奈何老板嫌微信自带的tabbar太丑而且功能也不够丰富,因此需要自定义tabbar,没办法就只能自己重新造一个,在造轮子之前从网上找了不少但都是直接使用navigateTo或者redirectTo实现跳转功能,每次都重新加载一下页面实在是受不了。

    在细读了微信的api文档后发现能够使用hideTabBar这个方法将原有的tabbar隐藏掉,这样只要自己重新写一个tabbar就可以了

    实现原理

    1. 利用 wx.hideTabBar({aniamtion: false}) 隐藏默认的tabbar

    2. 点击时使用 wx.switchTab 进行跳转

    优点:

    1. 自定义更好看的tabbar

    2. 相比其他用navigateTO实现的tabbar效果更好(没有页面跳转)

    3. 可以自定义页面跳转方式,比如第三个按钮的目标页面是一个二级页面,不需要tabbar

    缺点:

    1. 相比于原生的tabbar,首次进入页面的时候需要加载tabbar,导致初次切换到页面的时候tabbar会闪烁一下,视觉效果差点

    注:可以考虑在单页面中引入多个页面来避免闪烁的问题,但是这样开发的复杂度会高不少

    效果图:

    效果图

    2019-1-21 更新

    小程序有时ios下tabbar没有隐藏,为了保险起见在组件的生命周期内调用了多次 wx.hideTabBar

    2019/1/22 更新

    发现在ios下,在小程序全屏播放视频后回到页面内时tabbar会再次出现,因此如果有全屏播放视频的需求的话需要在视频对象的 bindfullscreenchange 事件中再次调用 wx.hideTabBar({aniamtion: false})

    (我不管,反正这是微信ios端的锅,不是我的代码有问题 ヽ(o`皿′o)ノ )

    2019/4/4 更新

    看文档时发现小程序官方在2.5.0出了一个自定义tabbar的功能,但是对版本库有要求,在低版本基础库下会降级成原生的tabbar样式(总觉得跟我自己写的也差不多,不过官方支持就更好了。。。)

  • 相关阅读:
    如何创建一个自定义和定制Windows窗体事件“跳转列表吗
    动画应用程序的主窗体
    Splasher v1.32 -启动屏幕实现
    颜色需要
    选项卡对话框类
    捕捉屏幕的各种方法
    列表生成方式
    关于日志监控中,关键字段如果还有.该如何处理
    oracle的一些状态查询
    rpm
  • 原文地址:https://www.cnblogs.com/wozho/p/9805257.html
Copyright © 2011-2022 走看看