前言
如果大家用过微信提供的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. 浏览器检测(BrowserDetect.js)使用

    浏览器检测是在工作中经常用到的,如果只是简单判断当前是什么浏览器的话可以通过window.navigator.useragent这样的js来直接判断就可以了! 但是针对浏览器版本要求比较高的时候,如果 ...

  2. word-wrap同word-break的区别

    兼容 IE 和 FF 的换行 CSS 推荐样式 最好的方式是 以下是引用片段: word-wrap:break-word; overflow:hidden; 而不是 以下是引用片段: word-wra ...

  3. DDD实践(一)

    DDD实践切入点(一) 前两篇:大型系统的支撑,应用系统开发思想的变迁 之前大致说了使用DDD的前期准备,现在可以真正开始实践了,以我刚刚结束的一个简单的经典DDD方式的项目为例子,当然由于比较简单, ...

  4. C#实现函数根据返回类型重载

    一直以来都很奇怪为何C#不能直接支持函数返回值重载, 比如如下两个函数是编译不过的 Public Class DbHelper { Public Static int ExecuteScalar(); ...

  5. 数据类型和typeof操作符

    虽然学习js有一段时间了,但是对js的基础语法却是有些生疏.最近在看jquery源码,决定随带总结一些基础的语法知识.今天总结一下数据类型和typeof,这在写js的时候,是不得不知道的知识. 数据类 ...

  6. EF6+MVC4+EasyUI个人日记系统开源共享

    发现在2015年里学习MVC的人越来越多,本人的群成员也越来越多,为了更方便大家学习,在此共享一个个人的小项目. 如下是部分截图: 简单介绍一下本系统的一些相关知识. 1.简单的3层框架,易学易懂 2 ...

  7. every、some、filter、map、forEach 方法的区别总结

    API功能描述: [every]:Boolean 遍历数组并执行回调,如果每个数组元素都能通过回调函数的测试则返回true,否则返回false.一旦返回false,将立即终止循环. [some]:Bo ...

  8. Ubuntu开启NFS,挂载根目录

    1.安装NFS server Ubuntu初始状态是没有NFS server的,首先要安装NFS server: $ sudo apt-get install nfs-kernel-server (安 ...

  9. Android学习笔记-Intent(一)

    Intent对象在Android官方API这样描述:It is a passive data structure holding an abstract description of an opera ...

  10. C# 多线程学习总结

    C# 多线程学习总结 C#多线程学习(一) 多线程的相关概念 什么是进程? 当一个程序开始运行时,它就是一个进程,进程包括运行中的程序和程序所使用到的内存和系统资源.而一个进程又是由多个线程所组成的. ...