在微信小程序中有关tabBar模板用法(详细教程)

这篇文章主要介绍了微信小程序tabbar模板用法,结合具体实例形式分析了tabbar模板的定义、配置、引用等相关操作技巧,需要的朋友可以参考下

本文实例讲述了微信小程序tabBar模板用法。分享给大家供大家参考,具体如下:

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

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

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

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

             {{item.text}}     

登录后复制

接下来进行测试,首先是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引入模板:


登录后复制登录后复制

接下来是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引入模板:


登录后复制登录后复制

最后演示如下:

在微信小程序中有关tabBar模板用法(详细教程)

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

1、app.js文件配置:

//app.jsvar 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];//相当于Page({})里面的this对象  var _pagePath=_curPage.__route__;  if(_pagePath.indexOf('/') != 0){   _pagePath='/'+_pagePath;  }  var tabBar=this.globalData.tabBar;  for(var i=0; i

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

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

登录后复制

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

在js中如何实现转换时间戳格式

在vue中如何获取dom元素

在vue中如何实现阅读全文

在webpack上如何搭建vue项目

以上就是在微信小程序中有关tabBar模板用法(详细教程)的详细内容,更多请关注【创想鸟】其它相关文章!

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

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2748882.html

(0)
上一篇 2025年3月8日 04:51:56
下一篇 2025年2月27日 17:49:52

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论