自定义底部导航栏(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翻译 ...
随机推荐
- How do I create an IIS application and application pool using InnoSetup script
Create an IIS application. Create a new IIS application pool and set it's .NET version to 4. Set the ...
- leetcode[94] Unique Binary Search Trees
给定n,那么从1,2,3...n总共可以构成多少种二叉查找数呢.例如给定3 Given n = 3, there are a total of 5 unique BST's. 1 3 3 2 1 \ ...
- Spring.Net+Nhibernate+Asp.Net Mvc 框架
搭建你的Spring.Net+Nhibernate+Asp.Net Mvc 框架 (一)搭建你的环境 使用这套框架不是很长时间.但也基本应用了几个项目中了.在此和大家分享一下我是怎样一步一步搭建此框架 ...
- Effective C++(15) 在资源管理类中提供对原始资源的访问
问题聚焦: 资源管理类是为了对抗资源泄露. 如果一些函数需要访问原始资源,资源管理类应该怎么做呢? 关于资源管理的概念总是显得那么的高大上,其实只是抽象一点. 下面用 ...
- Django部署到Apache Web Server
Windows环境下,将Django部署到Apache Web Server 在Windows上部署Django(用mod_wsgi)会出现各种奇怪的问题,现简单记录下配置过程及遇到的错误及解决方法. ...
- C#类的初始化
类的构造函数 类的构造函数,有实例构造函数和静态构造函数.如果我们没有构造函数,系统会为我们生成一个默认构造函数,如果我们已经定义了构造函数,系统就不会再为我们生成构造函数. class Simp ...
- [转]Apple iPod, iPhone (2g, 3g), iPad Dock connector pinout
Pin Signal Description Apple pin numbering* 1 GND Ground (-), internally connected with Pin 2 on iPo ...
- 基于Redis的CustomerSessionProvider(二)
接一的考虑,那么就做Redis的SessionProvider就非常简单了,只考虑整个Session的缓存,主要实现以下两个函数就可以了 public override SessionStateSto ...
- hadoop集群安装
首现非常感谢 虾皮(http://www.cnblogs.com/xia520pi/archive/2012/05/16/2503949.html) 安装过程是参照他的<Hadoop集群(第5期 ...
- LigerUI权限系统之用户管理
用户管理较之前的的组织结构和菜单管理稍显复杂.不管怎样还是先上图吧,再来讲解 左边是组织结构,右边是用户,用户是跟组织机构挂钩的,通过点击左边的组织结构,来刷新右边,加载该组织机构下的用户. 用户管理 ...