informasi kontak saya
Surat[email protected]
2024-07-12
한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina
Terapkan penyesuaian dalam program mini WeChat tabBar
Ini dapat memberikan menu navigasi bawah yang lebih fleksibel dan personal untuk aplikasi Anda.Karena program mini WeChat resmitabBar
Kemampuan konfigurasi terbatas, penyesuaiantabBar
Ini telah menjadi pilihan banyak pengembang untuk menerapkan navigasi bawah yang kompleks.Berikut ini adalah contoh sederhana bagaimana menerapkan kustomisasi dalam sebuah program minitabBar
。
Pertama, Anda perlu melakukannya app.json
Konfigurasi sedangtabBar
informasi dasar, tapicustom
Bidang perlu disetel ketrue
untuk mengaktifkan penyesuaiantabBar
。
{
"pages": [
"pages/index/index",
"pages/logs/logs",
"pages/profile/profile"
],
"window": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#fff",
"navigationBarTitleText": "WeChat",
"navigationBarTextStyle": "black"
},
"tabBar": {
"list": [
{
"pagePath": "pages/index/index",
"text": "首页"
},
{
"pagePath": "pages/logs/logs",
"text": "日志"
},
{
"pagePath": "pages/profile/profile",
"text": "我的"
}
],
"custom": true,
"color": "#7A7E83",
"selectedColor": "#3cc51f",
"borderStyle": "black"
}
}
Buat file bernama custom-tab-bar
folder dan buat file yang diperlukan di dalamnya (mis.index.js
、index.json
、index.wxml
、index.wxss
)。
Logikanya bisa diproses di sini, seperti berpindah tab berdasarkan halaman saat ini.
Component({
data: {
selected: 0,
list: [{
pagePath: '/pages/index/index',
text: '首页'
}, {
pagePath: '/pages/logs/logs',
text: '日志'
}, {
pagePath: '/pages/profile/profile',
text: '我的'
}]
},
methods: {
switchTab: function(e) {
const data = e.currentTarget.dataset;
if (this.data.selected === data.index) return;
wx.switchTab({url: data.path});
},
onShow: function(e) {
// 当 tabBar 显示时触发,可以根据需要获取当前页面路径
const { path } = getCurrentPages().pop();
this.setData({
selected: this.data.list.findIndex(tab => tab.pagePath === path)
});
}
}
});
Tentukan informasi konfigurasi komponen.
{
"usingComponents": {}
}
Tentukan struktur tabBar.
<view class="tab-bar">
<block wx:for="{{list}}" wx:key="index" wx:for-index="idx">
<view class="tab-item {{selected === idx ? 'active' : ''}}" data-path="{{item.pagePath}}" data-index="{{idx}}" bindtap="switchTab">
{{item.text}}
</view>
</block>
</view>
Tambahkan gaya.
.tab-bar {
display: flex;
justify-content: space-around;
background-color: #fff;
position: fixed;
bottom: 0;
left: 0;
right: 0;
height: 50px;
}
.tab-item {
padding: 10px 0;
text-align: center;
}
.tab-item.active {
color: #3cc51f;
}
ada app.js
Perkenalkan dan gunakan komponen tabBar khusus.
App({
onLaunch: function () {
// 在这里可以执行一些启动时的逻辑
},
usingComponents: {
'不同角色,控制查看底部菜单权限
实现效果1:实体店
实现效果2:回收公司
