前言
如果大家用过微信提供的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)的更多相关文章

  1. 微信小程序自定义底部导航栏组件+跳转

    微信小程序本来封装有底部导航栏,但对于想自定义样式和方法的开发者来说,这并不是很好. 参考链接:https://github.com/ljybill/miniprogram-utils/tree/ma ...

  2. uniapp 小程序实现自定义底部导航栏(tarbar)

    在小程序开发中,默认底部导航栏很难满足实际需求,好在官方给出了自定义形式,效果如下: 话不多说,直接上代码 1.组件 custom-tarbar.vue文件 <template> < ...

  3. 小程序 - 底部导航栏“tabBar”

    小程序底部导航 1.app.json页面配置: { "pages": [ "pages/movie/movie", "pages/cinema/cin ...

  4. 添加底部导航栏tabbar

    效果图: 如果要添加底部导航栏,最少2个,最多5个. app.json { "pages": [ "pages/index/index", "page ...

  5. 01 uni-app框架学习:项目创建及底部导航栏tabBar配置

    1.创建一个项目类型选择uniapp 2. pages里新建3个页面如下 3.在pages.json中配置底部导航tabBar 效果展示:

  6. 小程序 mpvue自定义底部导航栏

    1.在compontents新建文件放入 <template> <section class="tabBar-wrap"> <article clas ...

  7. 微信小程序从零开始开发步骤(三)底部导航栏

    上一章节,我们分享了如何创建一个新的页面和设置页面的标题,这一章我们来聊聊底部导航栏是如何实现的.即点击底部的导航,会实现不同对应页面之间的切换. 我们先来看个我们要实现的底部导航栏的效果图:(三个导 ...

  8. mui底部导航栏切换分页

    使用Hbuilder的mui框架开发移动端非常便利.高效: 底部导航栏切换功能也是移动APP开发中必须实现的: 引入mui文件.下面会用到jquery,同时引进 <link href=" ...

  9. Android开源项目——带图标文字的底部导航栏IconTabPageIndicator

    接下来的博客计划是,在<Android官方技术文档翻译>之间会发一些Android开源项目的介绍,直接剩下的几篇Android技术文档发完,然后就是Android开源项目和Gradle翻译 ...

随机推荐

  1. lucene简介 创建索引和搜索初步

    lucene简介 创建索引和搜索初步 一.什么是Lucene? Lucene最初是由Doug Cutting开发的,2000年3月,发布第一个版本,是一个全文检索引擎的架构,提供了完整的查询引擎和索引 ...

  2. Memcache存储大量数据的问题

    Memcache存储大数据的问题  huangguisu Memcached存储单个item最大数据是在1MB内,假设数据超过1M,存取set和get是都是返回false,并且引起性能的问题. 我们之 ...

  3. 证明中序遍历O(n)

    算法导论12.1 什么是二叉搜索树 二叉搜索树应满足的性质: 设x是二叉搜索树中的一个结点.如果y是x左子树中的一个结点,那么y.key <= x.key.如果y是右子树中的一个结点,那么y.k ...

  4. tsung 对 openfire 压力测试

    tsung 对 openfire 压力测试   1. 参考 http://blog.csdn.net/foxisme2/article/details/7521139 http://blog.csdn ...

  5. How feedback work for your improvement

    Why generally feedback is the perspective from others for some event. In China there is story,some k ...

  6. 凝结时光:ImageMagick 制作 gif

    从去年12.12开始,工作日都会从单位的落地窗向外拍一张照片,有点每日打卡的意思.weekday 是一天不落的,weekend 不是每次都到单位,落了几次. 想法来自上学的时候,有同学在同一个地方,拍 ...

  7. Android:开发环境搭建、移植

    一:搭建Android安卓开发环境 准备文件 1.eclipse-SDK-4.2-win32.zip 2.JDK(Java Development Kit) 3.ADT,安卓开发的一个eclipse的 ...

  8. Redis for Windows(C#缓存)配置文件详解

    Redis for Windows(C#缓存)配置文件详解   前言 在上一篇文章中主要介绍了Redis在Windows平台下的下载安装和简单使用http://www.cnblogs.com/aehy ...

  9. 【CSS】圆角阴影边框CSS

    .someClassName { width:300px; display: inline-block; padding: 5px 10px 6px; text-decoration: none; b ...

  10. web-worker计数器,根据输入时间统计次数

    1.用web-worker实现:另起一个线程,将计数工作运行在后台的JavaScript文件,并返回累加后的结果. 该js文件运行于后台,独立于其他脚本,不会影响页面的性能.html页面可以继续做任何 ...