自定义底部导航栏(tabBar)
前言
如果大家用过微信提供的tabBar就会发现,他的tabBar有很大的局限性。
暂且不说样式局限性了,他提供的app.json配置文件中没有function。
这也就意味着使用它提供的这个组件,你只能用于跳转页面,不能干其它的事情
我YY的

以下是代码
说明:小程序的很大异步分思想体现了封装,以提高复用性。对此,一些简单代码我也封装了,考虑到了以后维护的方便性
目录结构如下:

图片配置文件:imgURI.js(由于小程序不支持xml和读取本地json,故用js代替)
var host="/img/";
var arr={
//各种图片地址
log0:host+'log0.png',
log1:host+'log1.png',
my0:host+'my0.png',
my1:host+'my1.png',
add:host+'add.png'
}
function gets(arg){
return arr[arg];
}
module.exports ={
gets:gets
}
页面代码:index.wxml
<!--选项卡-->
<view class="tabBar">
<block wx:for="{{tabBar}}">
<view class="tarItem" bindtap="{{item.tarFunction}}" data-index="{{index}}" >
<image class="tarIco" src="{{item.tarIco}}"></image>
<view class="tarTxt" >{{item.tarTxt}}</view>
</view>
</block>
</view> <!--选项卡对应的页面-->
<view class="pages1" hidden="{{tabBar[0]['isHidden']}}">
pages1
</view>
<view class="pages2" hidden="{{tabBar[2]['isHidden']}}">
pages2
</view>
页面样式:index.wxss
.tabBar{width: 100%;
display: flex; flex-direction: row; justify-content:space-around;
position: fixed; bottom:;
border-top:red solid 1rpx; padding: 6rpx 0
}
.tarItem{text-align: center; font-size:30rpx; }
.tarIco{width: 60rpx; height: 60rpx}
页面逻辑:index.js
var imgURI_js = require('../../utils/imgURI.js');
Page({
data: {
//配置选项卡
tabBar:[
{
tarFunction:'log' ,
tarIco:imgURI_js.gets('log1'),
tarTxt:'日志', isHidden:false
},
{
tarFunction:'add',
tarIco:imgURI_js.gets('add'),
tarTxt:'添加', isHidden:true
},
{
tarFunction:'my' ,
tarIco:imgURI_js.gets('my0'),
tarTxt:'备忘', isHidden:true
}
]
},
//点击日志tab
log:function(e){
var that=this;
var click=e.currentTarget.dataset.index;
//回调支持3个参数,第1个是遍历的数组内容;第2个是对应的数组索引,第3个是数组本身。
that.data.tabBar.forEach(function(value, index, array){
if(index!=click){array[index]['isHidden']=true;}
else{array[index]['isHidden']=false; }
})
that.data.tabBar[0]['tarIco']=imgURI_js.gets('log1');
that.data.tabBar[2]['tarIco']=imgURI_js.gets('my0');
that.setData(that.data);
},
//点击添加tab
add:function(){
var that=this;
wx.showActionSheet({
itemList: ['新增日程', '新增备忘'],
success: function(res) {
console.log(res.tapIndex)
}
})
},
//点击备忘tab
my:function(e){
var that=this;
var click=e.currentTarget.dataset.index;
that.data.tabBar.forEach(function(value, index, array){
if(index!=click){array[index]['isHidden']=true;}
else{array[index]['isHidden']=false;}
});
that.data.tabBar[0]['tarIco']=imgURI_js.gets('log0');
that.data.tabBar[2]['tarIco']=imgURI_js.gets('my1');
that.setData(that.data);
}
})
页面所用图片
log0:http://i1.piimg.com/580831/21427560d907daa1.png
log1:http://i1.piimg.com/580831/7301f39e7cd93dd8.png
add:http://i1.piimg.com/580831/ce49d7bc59e84c46.png
my0:http://i1.piimg.com/580831/091ca02deae1664b.png
my1:http://i1.piimg.com/580831/c5118f811ed44e28.png
效果预览

完整项目下载:https://git.oschina.net/dingshao/wechatApp_tabBar.git
自定义底部导航栏(tabBar)的更多相关文章
- 微信小程序自定义底部导航栏组件+跳转
微信小程序本来封装有底部导航栏,但对于想自定义样式和方法的开发者来说,这并不是很好. 参考链接:https://github.com/ljybill/miniprogram-utils/tree/ma ...
- uniapp 小程序实现自定义底部导航栏(tarbar)
在小程序开发中,默认底部导航栏很难满足实际需求,好在官方给出了自定义形式,效果如下: 话不多说,直接上代码 1.组件 custom-tarbar.vue文件 <template> < ...
- 小程序 - 底部导航栏“tabBar”
小程序底部导航 1.app.json页面配置: { "pages": [ "pages/movie/movie", "pages/cinema/cin ...
- 添加底部导航栏tabbar
效果图: 如果要添加底部导航栏,最少2个,最多5个. app.json { "pages": [ "pages/index/index", "page ...
- 01 uni-app框架学习:项目创建及底部导航栏tabBar配置
1.创建一个项目类型选择uniapp 2. pages里新建3个页面如下 3.在pages.json中配置底部导航tabBar 效果展示:
- 小程序 mpvue自定义底部导航栏
1.在compontents新建文件放入 <template> <section class="tabBar-wrap"> <article clas ...
- 微信小程序从零开始开发步骤(三)底部导航栏
上一章节,我们分享了如何创建一个新的页面和设置页面的标题,这一章我们来聊聊底部导航栏是如何实现的.即点击底部的导航,会实现不同对应页面之间的切换. 我们先来看个我们要实现的底部导航栏的效果图:(三个导 ...
- mui底部导航栏切换分页
使用Hbuilder的mui框架开发移动端非常便利.高效: 底部导航栏切换功能也是移动APP开发中必须实现的: 引入mui文件.下面会用到jquery,同时引进 <link href=" ...
- Android开源项目——带图标文字的底部导航栏IconTabPageIndicator
接下来的博客计划是,在<Android官方技术文档翻译>之间会发一些Android开源项目的介绍,直接剩下的几篇Android技术文档发完,然后就是Android开源项目和Gradle翻译 ...
随机推荐
- javascript 学习总结(三)Boolean对象
Boolean对象 /* 创建 Boolean 对象的语法: new Boolean(value); //构造函数 Boolean(value); //转换函数 参数 value 由布尔对象存放的值或 ...
- 数据类型 text 和 varchar 在 add 运算符中不兼容
原文:数据类型 text 和 varchar 在 add 运算符中不兼容 在SQL Server2005中,使用类似下面的Update语句: 1 UPDATE tb_SmsBlacklist SET ...
- wcf事务(随记)
----------------------------------------------------wcf事务:1.ACID:原子性.一致性.隔离性.持久性:2.事务:添加命名空间(using S ...
- 点击表格的单元格时实现变颜色,通过for循环为每个单元格添加一个onclick事件
<title>无标题文档</title> <script type="text/javascript" language="javascri ...
- ASP.Net中应用百度编辑器(UEditor)上传图片和上传附件失败-解决方案
第一步: 第二步: 第三步: 第四步:
- SZU:A26 Anagram
Judge Info Memory Limit: 32768KB Case Time Limit: 10000MS Time Limit: 10000MS Judger: Normal Descrip ...
- poj3006 筛选法求素数模板(数论)
POJ:3006 很显然这是一题有关于素数的题目. 注意数据的范围,爆搜超时无误. 这里要用到筛选法求素数. 筛选法求素数的大概思路是: 如果a这个数是一个质数,则n*a不是质数. 用一个数组实现就是 ...
- vector如何进行局部排序
对于vector的全体排序,我们知道sort(vv.begin(),vv.end())来进行的. 但是对于如果是局部排序的话,比如,vector有100个元素,但我只想对10-80之间的数进行排序,如 ...
- webx学习1
webx的配置 如果想在web项目中使用webx框架,需要在web-inf/web.xml文件中进行相关的配置. 1.初始化spring容器 初始化spring容器- /web-inf/web.xml ...
- 替换__thread的一种方式,实现TLS功能
TLS是由于多线程编程带来的产物,主要是为了解决线程资源局部化,具体内容网上有很多介绍.有很多地方已经支持了该功能,但有些地方没有,下面是GCC的一些介绍,反正具体看实际使用情况: 5.51 Thre ...