温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

微信小程序怎么实现tabBar模板

发布时间:2022-04-08 10:52:22 来源:亿速云 阅读:138 作者:iii 栏目:编程语言

这篇文章主要讲解了“微信小程序怎么实现tabBar模板”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“微信小程序怎么实现tabBar模板”吧!

众所周知,微信小程序的tabBar都是新开页面的,而微信文档上又表明了最多只能打开5层页面。这样就很容易导致出问题啦,假如我的tabBar有5个呢?下面是微信原话:

一个应用同时只能打开5个页面,当已经打开了5个页面之后,wx.navigateTo不能正常打开新页面。请避免多层级的交互方式,或者使用wx.redirectTo

因此这几天想着根据微信tabBar数组来自定义模板供页面调用。不过我在list里面每个对象都增加了一个selectedColor和active属性,方便对每个tabBar当前页做样式,如果不传直接使用设置的selectedColor。因此这串数据只能设定在各个页面下,不能设定在公用的app.js配置文件下,稍微有点代码冗余,下次研究下怎么直接配置到app.js完善下。

只要新建一个tarBar.wxml模板页,然后引用模板的页面传入数据即可,代码如下:

<template name="tabBar">  <view class="flex-h flex-hsb tab-bar" >  <block wx:for="{{tabBar.list}}" wx:key="pagePath">   <navigator url="{{item.pagePath}}" open-type="redirect" class="menu-item" >    <image src="{{item.selectedIconPath}}" wx:if="{{item.active}}"></image>    <image src="{{item.iconPath}}" wx:if="{{!item.active}}"></image>    <text>{{item.text}}</text>   </navigator>   </block>  </view> </template>

接下来进行测试,首先是index.js的配置对象:

//配置tabBar   tabBar: {    "color": "#9E9E9E",    "selectedColor": "#f00",    "backgroundColor": "#fff",    "borderStyle": "#ccc",    "list": [     {      "pagePath": "/pages/index/index",      "text": "主页",      "iconPath": "../../img/tabBar_home.png",      "selectedIconPath": "../../img/tabBar_home_cur.png",      //"selectedColor": "#4EDF80",      active: true     },     {      "pagePath": "/pages/village/city/city",      "text": "目的地",      "iconPath": "../../img/tabBar_village.png",      "selectedIconPath": "../../img/tabBar_village_cur.png",      "selectedColor": "#4EDF80",      active: false     },     {      "pagePath": "/pages/mine/mine",      "text": "我的",      "iconPath": "../../img/tabBar_mine.png",      "selectedIconPath": "../../img/tabBar_mine_cur.png",      "selectedColor": "#4EDF80",      active: false     }    ],    "position": "bottom"   }

index.wxml引入模板:

<import src="../../template/tabBar.wxml" /> <template is="tabBar" data="{{tabBar: tabBar}}" />

接下来是mine.js文件引入配置对象:

//配置tabBar   tabBar: {    "color": "#9E9E9E",    "selectedColor": "#f00",    "backgroundColor": "#fff",    "borderStyle": "#ccc",    "list": [     {      "pagePath": "/pages/index/index",      "text": "主页",      "iconPath": "../../img/tabBar_home.png",      "selectedIconPath": "../../img/tabBar_home_cur.png",      //"selectedColor": "#4EDF80",      active: false     },     {      "pagePath": "/pages/village/city/city",      "text": "目的地",      "iconPath": "../../../img/tabBar_village.png",      "selectedIconPath": "../../../img/tabBar_village_cur.png",      "selectedColor": "#4EDF80",      active: false     },     {      "pagePath": "/pages/mine/mine",      "text": "我的",      "iconPath": "../../img/tabBar_mine.png",      "selectedIconPath": "../../img/tabBar_mine_cur.png",      "selectedColor": "#4EDF80",      active: true     }    ],    "position": "bottom"   }

mine.wxml引入模板:

<import src="../../template/tabBar.wxml" /> <template is="tabBar" data="{{tabBar: tabBar}}" />

最后演示如下:

微信小程序怎么实现tabBar模板

方案二,我把配置数据统一放在app.js文件,通过点击跳转页面后在把数据添加到当前页面实例上,具体做法如下:

1、app.js文件配置:

//app.js var net = require('common/net'); var a_l, a_d = {}, a_cbSucc, a_cbSuccFail, a_cbFail, a_cbCom, a_h, a_m; App({  onLaunch: function () {   var that = this;  },  //修改tabBar的active值  editTabBar: function () {   var _curPageArr = getCurrentPages();   var _curPage = _curPageArr[_curPageArr.length - 1];<span >//相当于Page({})里面的this对象</span>   var _pagePath=_curPage.__route__;   if(_pagePath.indexOf('/') != 0){    _pagePath='/'+_pagePath;   }   var tabBar=this.globalData.tabBar;   for(var i=0; i<tabBar.list.length; i++){    tabBar.list[i].active=false;    if(tabBar.list[i].pagePath==_pagePath){     tabBar.list[i].active=true;//根据页面地址设置当前页面状态    }   }   _curPage.setData({    tabBar: tabBar   });  },  globalData: {   userInfo: null,   //配置tabBar   tabBar: {    "color": "#9E9E9E",    "selectedColor": "#f00",    "backgroundColor": "#fff",    "borderStyle": "#ccc",    "list": [     {      "pagePath": "/pages/index/index",      "text": "主页",      "iconPath": "/pages/templateImg/tabBar_home.png",      "selectedIconPath": "/pages/templateImg/tabBar_home_cur.png",      "selectedColor": "#4EDF80",      active: false     },     {      "pagePath": "/pages/village/city/city",      "text": "目的地",      "iconPath": "/pages/templateImg/tabBar_village.png",      "selectedIconPath": "/pages/templateImg/tabBar_village_cur.png",      "selectedColor": "#4EDF80",      active: false     },     {      "pagePath": "/pages/mine/mine",      "text": "我的",      "iconPath": "/pages/templateImg/tabBar_mine.png",      "selectedIconPath": "/pages/templateImg/tabBar_mine_cur.png",      "selectedColor": "#4EDF80",      active: false     }    ],    "position": "bottom"   }  } })

2、index.js+mine.js+city.js页面使用:

var App=getApp(); Page({  data:{   detail: {},  },  onLoad:function(options){   App.editTabBar();//添加tabBar数据   var that=this;  } })

感谢各位的阅读,以上就是“微信小程序怎么实现tabBar模板”的内容了,经过本文的学习后,相信大家对微信小程序怎么实现tabBar模板这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI