小程序自定义tabbar的两种方式

小程序自定义tabbar的两种方式小程序自定义tabbar先做一下效果展示吧本案例是按照官网来做的app.js代码:“tabBar”:{“custom”:true,“color”:“#000000”,“selectedColor”:“#000000”,“backgroundColor”:“#000000”,“borderStyle”:“white”,“list”:[{“pagePath”:…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

小程序自定义tabbar

先做一下效果展示吧
在这里插入图片描述
在这里插入图片描述

本案例是按照官网来做的

app.js代码:

下面的list,官网说是必须的,但我感受不到它的用处

"tabBar": { 
   
    "custom": true,
    "color": "#000000",
    "selectedColor": "#000000",
    "backgroundColor": "#000000",
    "borderStyle": "white",
    "list": [
      { 
   
        "pagePath": "pages/page/index",
        "text": "首页",
        "iconPath": "/imgs/tab.png",
        "selectedIconPath": "/imgs/tab.png"
      },
      { 
   
        "pagePath": "pages/scroll/index",
        "text": "滚动",
        "iconPath": "/imgs/tab.png",
        "selectedIconPath": "/imgs/tab.png"
      }
    ]
  },
  "usingComponents": { 
   }

Jetbrains全家桶1年46,售后保障稳定

tabbar组件的创建

在这里插入图片描述
在根目录下创建custom-tab-bar目录,然后在该目录下新建组件component,注意是组件,不要建成page页面,虽然都一样是js/json/wxml/wxss四个文件

custom-tab-bar/index.js代码
data: { 
   
  curIndex: 0,
  color: "#00f",
  selectedColor: "#ff0",
  list: [
    { 
   
      pagePath: "/pages/page/index",
      iconPath: "/imgs/tab.png",
      selectedIconPath: "/imgs/tab1.png",
      text: "首页"
    }, { 
   
      pagePath: "/pages/scroll/index",
      iconPath: "/imgs/tab.png",
      selectedIconPath: "/imgs/tab1.png",
      text: "滚动"
    },
  ]
},
methods: { 
   
  switchTab(e) { 
   
    let url = e.currentTarget.dataset.url
    let index = e.currentTarget.dataset.index
    wx.switchTab({ 
   
      url
    })
    // this.setData({ 
   
    // curIndex:index
    // })
    wx.setStorageSync('curIndex', index)
  },
}
custom-tab-bar/index.wxml代码
<cover-view class="container">
  <cover-view class="item" bindtap='switchTab' wx:for="{ 
    {list}}" wx:key="{ 
    {index}}" data-index="{ 
    {index}}" data-url="{ 
    {item.pagePath}}">
    <cover-image class="icon" src='{ 
    {index==curIndex?item.selectedIconPath:item.iconPath}}'></cover-image>
    <cover-view class="text" class="{ 
    {index==curIndex?'textStyle':''}}">{
  
  {item.text}}</cover-view>
  </cover-view>
</cover-view>
custom-tab-bar/index.wxss代码
.container{ 
   
  height: 120rpx;
  background:green;
  display: flex;
}
.item{ 
   
  flex:1;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: space-around;
}
.icon{ 
   
  width:60rpx;
  height: 60rpx;
  margin:0 auto;
}
.textStyle{ 
   
  color:#fff;
}

最好给自定义tabbar设置一个高度,这样的话,如果页面需要用到scroll-view那高度也好控制,scroll-view的精确控制可以参考scroll的高度设置

最后,设置tabbar的选中状态,要在每个tab页面的onShow中设置
if (typeof this.getTabBar === 'function' && this.getTabBar()) { 
   
      this.getTabBar().setData({ 
   
        curIndex: 1
      })
    }
自定义tabbar就这样可以了

但是,
问题一:进入小程序第一次进行tabbar切换的时候有闪烁问题
问题二:本案例的启动页是首页,第一次切换到滚动也的时候除了闪烁问题外,scroll-view的高度也比正常情况下小了100rpx(正好是滚动页中topNav的高度),下图是滚动页代码

<view class="topNav"></view>
<scroll-view style="{ 
      { 
      'height:'+scrollHeight+'px'}}" scroll-y>
  <view class="red"></view>
  <view class="blue"></view>
  <view class="red"></view>
  <view class="blue"></view>
  <view class="red"></view>
  <view class="blue"></view>
</scroll-view>

所以本例的自定义tabbar就实现了
(ps:如果滚动页设置为启动页,就不会有问题二的出现)
闪烁问题,网上也找不到解决的办法,官网也未提及,希望有办法的朋友分享给我
如果想要避免上述问题,来一个完美的tabbar的话,就不要使用官网的方法,而采用单页面的形式

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/209948.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • linux initramfs,Linux INITRAMFS 与 INITRD「建议收藏」

    linux initramfs,Linux INITRAMFS 与 INITRD「建议收藏」initramfs文件生效的过程大致分为四步:第一步:Kernel首先要注册一个RAMFS文件系统类型(实际注册的类型名称是”ROOTFS”,后续我们可以看到它实际上就是”RAMFS”);第二步:然后加载(mount)一个空的rootfs文件系统,类型就是上面提到的RAMFS(ROOTFS);第三步:寻址initramfs文件“XXX.cpio.gz”并解压到已mount的rootfs文件系统中;…

    2022年8月11日
    9
  • 设置matlab保存的图片没有白边,matlab如何保存figure中去掉白边的图片「建议收藏」

    设置matlab保存的图片没有白边,matlab如何保存figure中去掉白边的图片「建议收藏」输出图片成可直接调入的灰度图,设置输出图片空白边距,以及调整图片大小,纵横比。一、先显示图片,imshow。如果是plot,或者newplot,直接看“三”。imshow(strain_image,’border’,’tight’,’initialmagnification’,’fit’);%’border’,’tight’的组合功能意思是去掉图像周边空白%’InitialMagnificatio…

    2025年8月26日
    6
  • vmware15激活码【永久激活】「建议收藏」

    (vmware15激活码)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~MLZPB5EL5Q-eyJsaWNlbnNlSWQiOi…

    2022年3月21日
    115
  • pycharm创建虚拟环境及具体(意义)说明

    pycharm创建虚拟环境及具体(意义)说明创建虚拟环境意义 假设做项目 A 用的包版本要是 selenium2 48 0 和 lxml 1 0 0 做项目 B 必须用包版本是 selenium2 50 0 和 lxml 1 2 0 拿就要把 selenium2 48 0 和 lxml 1 0 0 卸载了并安装 selenium2 50 0 和 lxml 1 2 0 但是这样换做类似项目 A 的包版本要求又得把以前的卸载了 装回 selenium2 48

    2025年12月6日
    4
  • 亿图图示2021用户名和密钥激活码 mac【2021.7最新】[通俗易懂]

    (亿图图示2021用户名和密钥激活码 mac)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.htmlMLZPB5EL5Q-eyJsaWNlbnNlSW…

    2022年3月21日
    5.5K
  • Python 获取窗口句柄,模拟鼠标点击

    Python 获取窗口句柄,模拟鼠标点击一、效果图二、代码importwin32guiimportwin32apiimportpyautogui#frompymouseimportPyMousehwnd_title={}defget_all_hwnd(hwnd,mouse):if(win32gui.IsWindow(hwnd)andwin32gui.IsWindowEnabled(hwnd)andwin32gui.IsWindowVisible(hwnd)

    2022年7月21日
    15

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号