電商底部導覽列的製作
我想大家對電商一定不陌生,一般電商的底部導覽列有以下幾個首頁、分類、購物車、個人中心。
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 大家可以根據我的圖片路徑建立對應的資料夾,如下圖

需要注意的:
- #添加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裡的第一行路徑作為默認勾選項的。
既然講了導覽欄,乾脆今天多講解一點,接著教大家頂部導覽列怎麼製作,先上效果圖

这个导航栏可不像底部导航栏啦,因为他的级别比较低,是页面级别的导航栏,所以要写在页面里,你想要在哪个页面加入顶部导航栏就在哪个页面里添加如下代码,这里以首页的界面为例:
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,字段可以自由命名,赋值的时候对应上就好,
navbarTap 记得在home.wxml里面data-idx属性吗,在这里用到,currentTab: e.currentTarget.dataset.idx 把当前用户选择的Tab传给currentTab里,为了验证一下结果,我在这里面加入了一个输出日志console.debug(e);,可以在控制台上看输出的日志,我选择点击彩妆,输出台的数据idx:1刚好是彩妆的位置。

总结
今天我们讲解的微信小程序的底部导航栏和顶部导航栏,导航栏应该说是必须的对于电商小程序来说,那么今天的导航栏教程你掌握了吗?
学习过程中遇到什么问题或者想获取学习资源的话,欢迎加入学习交流群
以上是分享一個小程式開發實戰的詳細內容。更多資訊請關注PHP中文網其他相關文章!

HTML的作用是通過標籤和屬性定義網頁的結構和內容。 1.HTML通過到、等標籤組織內容,使其易於閱讀和理解。 2.使用語義化標籤如、等增強可訪問性和SEO。 3.優化HTML代碼可以提高網頁加載速度和用戶體驗。

htmlisaspecifictypefodyfocusedonstructuringwebcontent,而“代碼” badlyLyCludEslanguagesLikeLikejavascriptandPytyPythonForFunctionality.1)htmldefineswebpagertuctureduseTags.2)“代碼”代碼“ code” code code code codeSpassSesseseseseseseseAwiderRangeLangeLangeforLageforLogageforLogicIctInterract

HTML、CSS和JavaScript是Web開發的三大支柱。 1.HTML定義網頁結構,使用標籤如、等。 2.CSS控製網頁樣式,使用選擇器和屬性如color、font-size等。 3.JavaScript實現動態效果和交互,通過事件監聽和DOM操作。

HTML定義網頁結構,CSS負責樣式和佈局,JavaScript賦予動態交互。三者在網頁開發中各司其職,共同構建豐富多彩的網站。

HTML適合初學者學習,因為它簡單易學且能快速看到成果。 1)HTML的學習曲線平緩,易於上手。 2)只需掌握基本標籤即可開始創建網頁。 3)靈活性高,可與CSS和JavaScript結合使用。 4)豐富的學習資源和現代工具支持學習過程。

AnexampleOfAstartingTaginHtmlis,beginSaparagraph.startingTagSareEssentialInhtmlastheyInitiateEllements,defiteTheeTheErtypes,andarecrucialforsstructuringwebpages wepages webpages andConstructingthedom。

如何設計菜單中的虛線分割效果?在設計菜單時,菜名和價格的左右對齊通常不難實現,但中間的虛線或點如何...

網頁代碼編輯器中的HTML元素分析許多在線代碼編輯器允許用戶輸入HTML、CSS和JavaScript代碼。最近,有人提出了一...


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

Atom編輯器mac版下載
最受歡迎的的開源編輯器

WebStorm Mac版
好用的JavaScript開發工具

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。