文章目录
一、前言
一般使用tabBar的样式,固定不能改变。如下固定效果图:
如何自定义自己想要的效果图呢,举个例子。如下自定义效果图:
二、固定效果图实现步骤
使用微信开发者工具-创建项目我就不说了,官方文档很详细。
参考:官方文档介绍
实现步骤
添加images文件,添加想要的矢量图(可通过阿里巴巴矢量图免费获取)
2、在app.json文件中,编辑代码
3、保存,刷新即可
完整代码-矢量图
images图片
app.json代码
{ "pages":[ "pages/index/index", "pages/logs/index", "pages/commdt/index", "pages/cart/index", "pages/mymessage/index" ], "window":{ "backgroundTextStyle":"light", "navigationBarTitleText": "测试tabbar", "navigationBarTextStyle":"white" }, "tabBar": { "color": "#B6B6B6", "selectedColor": "#FE9132", "list": [ { "pagePath":"pages/index/index", "text": "首页", "iconPath":"/images/sy2.png", "selectedIconPath": "/images/sy1.png" }, { "pagePath":"pages/commdt/index", "text": "商品", "iconPath":"/images/sp2.png", "selectedIconPath": "/images/sp1.png" }, { "pagePath":"pages/cart/index", "text": "购物车", "iconPath":"/images/gwc2.png", "selectedIconPath": "/images/gwc1.png" }, { "pagePath":"pages/mymessage/index", "text": "我的", "iconPath":"/images/wd2.png", "selectedIconPath": "/images/wd1.png" } ] }, "style": "v2", "sitemapLocation": "sitemap.json"}
三、自定义效果图实现步骤
实现步骤
添加images文件,添加想要的矢量图(可通过阿里巴巴矢量图免费获取)
2、在app.json文件中,编辑代码
3、点击加号,在根目录新建一个custom-tab-bar文件夹
4、然后右键该文件夹,点击新建components,输入index,回车,就会自动创建四个文件
此时我们可以看到小程序底部出现,就代表创建成功了。因为他自动识别了tabBar页面。
然后在该目录下编写代码即可
完整代码-矢量图
images图片
app.json代码
"window":{ "backgroundTextStyle":"light", "navigationBarBackgroundColor": "#FFFFFF", "navigationBarTitleText": "摆烂鸭", "navigationBarTextStyle":"black" }, "tabBar":{ "custom": true, "list":[ { "pagePath":"pages/index/index", "text":"摆鸭" },{ "pagePath":"pages/commdt/index", "text":"不鸭" } ] },
custom-tab-bar下的代码
index.wxml
<cover-view class="tab-bar"> <!-- <cover-view class="tab-bar-border"></cover-view> --> <cover-view wx:for="{{list}}" wx:key="index" class="tab-bar-item" data-path="{{item.pagePath}}" data-index="{{index}}" bindtap="switchTab"> <cover-image src="{{selected === index ? item.selectedIconPath : item.iconPath}}"></cover-image> <!-- <cover-view class="{{currentName == item.name ? 'text-active' : 'tabbar-text'}}">{{item.text}}</cover-view> --> </cover-view></cover-view>
index.css
.tab-bar { position: fixed; bottom: 0; left: 0; right: 0; height: 130rpx; background: white; display: flex; padding-bottom: env(safe-area-inset-bottom); justify-content: center;}.tab-bar-item { text-align: center; display: flex; flex-direction: column;}.tab-bar-item cover-image { width: 240rpx; height: 100rpx;}.tab-bar-item cover-view { font-size: 10px;}
index.js
Component({ properties: { }, data: { selected: 0, color: "#7A7E83", selectedColor: "#3cc51f", list: [{ "pagePath": "/pages/index/index", "iconPath": "/images/by3.png", "selectedIconPath": "/images/by1.png", "text": "摆鸭" }, { "pagePath": "/pages/commdt/index", "iconPath": "/images/by2.png", "selectedIconPath": "/images/by4.png", "text": "不鸭" }] }, methods: { switchTab(e) { console.log("执行跳转", e); const data = e.currentTarget.dataset const url = data.path wx.switchTab({ url }) this.setData({ selected: data.index }) } }})
使用自定义TaBar
使用自定义TabBar,在切换的TabBar界面的onShow中添加如下代码。如首页中设置 selected: 0,我的中设置 selected: 2。因为 selected: 1 是特殊跳转,点击加号图标时,不再是切换tabbar,而是直接跳转发布界面了。
例如:
/pages/index/index 的.js页面添加代码
onShow() { if (typeof this.getTabBar === 'function' && this.getTabBar()) { this.getTabBar().setData({ //唯一标识(其它设置不同的整数) selected: 0 }) } },
/pages/commdt/index 的.js页面添加代码
onShow() { if (typeof this.getTabBar === 'function' && this.getTabBar()) { this.getTabBar().setData({ //唯一标识(其它设置不同的整数) selected: 1 }) } },
各位看官》创作不易,点个赞!!!
诸君共勉:万事开头难,只愿肯放弃。
免责声明:本文章仅用于学习参考
来源地址:https://blog.csdn.net/SoulNone/article/details/127933751