電商底部導覽列的製作
我想大家對電商一定不陌生,一般電商的底部導覽列有以下幾個首頁、分類、購物車、個人中心。
app.json是用來配置page路徑以及導航列屬性的,那我們要做首頁、分類、購物車、個人中心界面就要在page也添加這幾個界面,所以在app. json的page加入如下程式碼,寫入page路徑,系統會自動幫你創建介面的
"pages":["pages/home/home","pages/classify/classify", "pages/cart/cart","pages/mine/mine","pages/index/index"
],
登入後複製
好,既然加入了四個介面,那我們要怎麼做底部導覽列吶,今天給app .json再增加一個屬性,就是可以在app.json裡配置導航欄,將下面程式碼加入app.json裡面
"tabBar": {"color": "#858585","selectedColor": "#f0145a","backgroundColor": "#ffffff","borderStyle": "#000","list": [
{"pagePath": "pages/home/home","iconPath": "images/bottomNav/home.png","selectedIconPath": "images/bottomNav/home_select.png","text": "首页"
},
{"pagePath": "pages/classify/classify","iconPath": "images/bottomNav/classify.png","selectedIconPath": "images/bottomNav/classify_select.png","text": "分类"
},
{"pagePath": "pages/cart/cart","iconPath": "images/bottomNav/cart.png","selectedIconPath": "images/bottomNav/cart_select.png","text": "购物车"
},
{"pagePath": "pages/mine/mine","iconPath": "images/bottomNav/mine.png","selectedIconPath": "images/bottomNav/mine_select.png","text": "我的"
}
]
}
登入後複製
tabBar系統自帶字段,不可改,加入這個字段就是告訴系統你要新增導覽欄,color、selectedColor、backgroundColor從字面意思也字段,分別對應的屬性是預設字體顏色、勾選字體顏色、背景顏色。著重說一下borderStyle,這個的定義底部導覽列與介面的邊界線,屬性有點特殊,特殊在如果你不想要這個分界線,可以把屬性設定為white,剩下的不管你寫入的是什麼,系統都理解為要添加這條分界線,不信你可以試試。 list屬性自然是設定對應導覽列的介面啦,
- ##pagePath:頁面路徑,就是你寫在page裡的路徑
- iconPath :預設導覽列圖片路徑
- selectedIconPath:勾選圖片的路徑
##text:導覽列名字 這裡要說的是,圖片路徑,一定要寫對,不然找不到圖片就顯示不出來,這裡給大家提供我的導航欄圖片---提取碼:8zwe 大家可以根據我的圖片路徑建立對應的資料夾,如下圖
1-1.png
需要注意的:
#添加tabBar的時候別忘記別忘記上面有一個逗號,這個是用來區分每個屬性的,所以你每添加一個屬性都要用逗號分隔開來,這點要注意,不然會報錯,這就是我把標點去掉的錯誤日誌,一般報出錯誤日誌Expecting 'EOF' XXXXXXXXX,got STRING都是語法錯誤,所以要仔細檢查看看哪裡少寫了東西。
1-2.png
#還有就是在.json檔案裡是不可以寫註解的,我原本想加入一點註解方便讀者閱讀,然而會出現下面錯誤訊息,解決辦法很簡單,把註解刪除就可以啦
1 -3.png
舉一反三
我們建立了四個導覽欄,那麼如果我想再增加兩個導覽列可以嗎? - 你也許覺得很簡單,試著去在list列表裡加兩個了吧,我也是這麼做的,但是出問題啦。系統會報錯,這回知道了吧,最多只能是五個,沒辦法,誰讓微信是老大,人家定最多五個那就只能最多五個嘍!
1-3.png
#你不知道你有沒有註意到,導覽列預設首頁勾選為紅色,那我想要預設勾選分類為紅色吶,該怎麼辦? - 這個有點難度了吧,我剛開始想的是在tabBar屬性把list裡的第一個home屬性和classify屬性換一下應該就可以解決,然而並不是這樣的,因為沒有效果,後來也是一次誤打誤撞給發現的,我給你點小提示,有沒有註意到,pages的第一個路徑是什麼pages/home/home,沒錯,就是它,如果想要分類classify作為預設的勾選項,你只需要在pages屬性把home的路徑和classify路徑換一下,保存,重新編譯一下,你要的效果就出來了,這裡可以總結的一點就是,tabBar是到page裡的第一行路徑作為默認勾選項的。
電商頂部導覽列製作
既然講了導覽欄,乾脆今天多講解一點,接著教大家頂部導覽列怎麼製作,先上效果圖
2-1.png
#
这个导航栏可不像底部导航栏啦,因为他的级别比较低,是页面级别的导航栏,所以要写在页面里,你想要在哪个页面加入顶部导航栏就在哪个页面里添加如下代码,这里以首页的界面为例:
home.wxss
/* pages/home/home.wxss */page{
display: flex;
flex-direction: column;
height: 100%;
}
.navbar{
flex: none;
display: flex;
background: #fff;
}
.navbar .item{
position: relative;
flex: auto;
text-align: center;
line-height: 80rpx;
font-size:14px;
}
/* 顶部导航字体颜色 */.navbar .item.active{
color: #f0145a;
}
/* 顶部指示条属性 */.navbar .item.active:after{
content: "";
display: block;
position: absolute;
bottom: 0;
left: 0;
right: 0;
height: 6rpx;
background: #f0145a;
}
登入後複製
home.wxml
<!--导航条-->
<view class="navbar">
<text wx:for="{{navbar}}" data-idx="{{index}}" class="item {{currentTab==index ? 'active' : ''}}" wx:key="unique" bindtap="navbarTap">{{item}}</text>
</view>
登入後複製
在home.wxml里面bindtap字段我们已经讲解过啦,是事件监听的标识符,事件名称叫“navbarTap”可以到home.js里查找到这个事件wx:for这个字段重点讲解,在组件上使用wx:for控制属性绑定一个数组,即可使用数组中各项的数据重复渲染该组件。默认数组的当前项的下标变量名默认为index,数组当前项的变量名默认为item,这是官方解释,说白了就是item默认叫做变量的值,index表示第几个变量的值,还不太明白请看这个 微信 wx:for 的讲解
wx:for="{{navbar}}" 意思是虚幻navbar的数组数据
{{item}} 这里面是navbar数组里面的值,如护肤、彩妆等值
wx:key="unique" 来指定列表中项目的唯一的标识符
data-idx="{{index}}" 存储一些数据供home.js里调用,这里data-xxx,xxx就是你给home.js里提供的数据关键词,home.js通过获取xxx关键词来获取xxx里面的数据
home.js
// pages/home/home.jsvar app = getApp()
Page({ data: {navbar: ['护肤', '彩妆', '香水','个人护理'],currentTab: 0,
}, // 导航切换监听
navbarTap: function (e) {console.debug(e);this.setData({ currentTab: e.currentTarget.dataset.idx
})
},
})
登入後複製
home.js,这里读过微信小程序入门篇(二)都知道,page页面里.js一般是放data数据和事件监听的,这里data有一个navbar导航栏数据,还有一个记录当前位置的currentTab,字段可以自由命名,赋值的时候对应上就好,
2-2.png
总结
今天我们讲解的微信小程序的底部导航栏和顶部导航栏,导航栏应该说是必须的对于电商小程序来说,那么今天的导航栏教程你掌握了吗?
学习过程中遇到什么问题或者想获取学习资源的话,欢迎加入学习交流群
以上是分享一個小程式開發實戰的詳細內容。更多資訊請關注PHP中文網其他相關文章!
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
-
1970-01-01 08:00:00
-
1970-01-01 08:00:00
-
1970-01-01 08:00:00
-
1970-01-01 08:00:00
-
1970-01-01 08:00:00
-
1970-01-01 08:00:00
-
1970-01-01 08:00:00
-
1970-01-01 08:00:00
-
1970-01-01 08:00:00
-
1970-01-01 08:00:00