一個側(cè)邊欄導(dǎo)航組件實現(xiàn)思路
在這篇文章中,我想和大家分享我是如何為 web 原型化一個 Sidenav 組件的,這個組件是響應(yīng)式的,有狀態(tài)的,支持鍵盤導(dǎo)航,可以使用和不使用 Javascript,并且可以跨瀏覽器工作。
構(gòu)建一個響應(yīng)式導(dǎo)航系統(tǒng)是很困難的。有些用戶使用鍵盤,有些用戶使用強(qiáng)大的臺式機(jī),還有一些用戶使用小型移動設(shè)備訪問。每個訪問者都應(yīng)該能夠打開和關(guān)閉菜單。

桌面到移動設(shè)備響應(yīng)式布局演示
用了哪些技術(shù)
在這次組件探索中,我很高興地結(jié)合了一些關(guān)鍵的網(wǎng)絡(luò)平臺特性:
- 偽類
- CSS Grid
- transforms
- 媒體查詢和用戶偏好 CSS
- 用戶增強(qiáng)體驗
我的解決方案只有一個側(cè)邊欄,只有在“移動”視口為540px 或更小時才能切換。540px 將是我們在移動交互式布局和靜態(tài)桌面布局之間切換的斷點。
偽類
一個<a> 鏈接將 url 散列設(shè)置為 #sidenav-open,另一個設(shè)置為 empty('')。最后,一個元素具有匹配散列的 id:
- <a href="#sidenav-open" id="sidenav-button" title="Open Menu" aria-label="Open Menu">
- <a href="#" id="sidenav-close" title="Close Menu" aria-label="Close Menu"></a>
- <aside id="sidenav-open"></aside>
點擊這些鏈接會改變我們網(wǎng)頁 URL 的散列狀態(tài),然后用一個偽類來顯示和隱藏 Sidenav:
- @media (max-width: 540px) {
- #sidenav-open {
- visibility: hidden;
- }
- #sidenav-open:target {
- visibility: visible;
- }
- }
CSS Grid
在過去,我只使用絕對或固定位置 Sidenav 布局和組件。不過,使用網(wǎng)格區(qū)域語法,可以為同一行或列分配多個元素。
Stacks
主要的布局元素 #sidenav-container 是一個網(wǎng)格,它創(chuàng)建了 1 行和 2 列,其中 1 列被命名為 stack。當(dāng)空間受到限制時,CSS 會將所有
菜單背景