js實(shí)現(xiàn)水平滾動(dòng)菜單導(dǎo)航
項(xiàng)目中用到了滾動(dòng)導(dǎo)航,但是默認(rèn)的滾動(dòng)條太丑了,只好用js自己模擬了一個(gè)。湊合用可以,不算完美。希望以后有機(jī)會(huì)再來修飾一下。
先來看下最終效果:

最終效果
先看html結(jié)構(gòu):
<div id='root' class="root"> <ul class="list" id="list"> <li>全單1</li> <li>全部菜2單</li> <li>全部3單</li> <li>菜單4</li> <li>全菜單</li> <li>全部5菜單</li> <li>全6單</li> <li>全6部菜單</li> <li>全菜7單</li> <li>全8單</li> <li>全部5菜單</li> <li>全6單</li> <li>全6部菜單</li> <li>全菜7單</li> <li>全8單</li> <li>全9部菜單</li> <li>全10單</li> <li>全11部單</li> <li>菜2單</li> <li>全菜12單</li> <li>全32部菜單</li> </ul> </div>
說一下,末尾我給加了陰影的效果:
.root:before{
display: block;
content: '';
width: 20px;
height:100%;
background: rgba(111,111,111,0);
box-shadow: 2px 2px 32px 2px #999;
position: absolute;
right:-20px;
top:0;
}
其它的樣式代碼:
*{
margin: 0;
padding:0;
font-family: "Microsoft YaHei UI";
}
#root{
height:60px;
width: 800px;
white-space: nowrap;
overflow: hidden;
-webkit-overflow-scrolling: touch;
white-space: nowrap;
position: relative;
border-bottom: 1px solid #eee;
padding-right: 20px;
background-color: #f5f5f5;
margin-left: 100px;
margin-top: 50px;
}
.root:before{
display: block;
content: '';
width: 20px;
height:100%;
background: rgba(111,111,111,0);
box-shadow: 2px 2px 32px 2px #999;
position: absolute;
right:-20px;
top:0;
}
.list{
position: absolute;
left:0;
top:0;
/*width: 100%;*/ /*不能為100%,不然寬度只有父容器的寬度,我掉進(jìn)這個(gè)坑了。*/
transition: all 1s;
height:100%;
line-height: 2.5;
}
.on{
color:red;
font-weight: bold;
}
.off{
color: #000;
font-weight:normal;
}
.list li{
display: inline-block;
padding:10px 20px;
cursor: pointer;
}
下面是js的邏輯部分:
var box = document.getElementById('root'); //外面的容器。
var listBox = document.getElementById('list'); //ul列表。主要是移動(dòng)它的left值
var list = document.getElementsByTagName('li');//所有列表元素
var width = box.clientWidth /2; //為了判斷是左滑還是右滑
var totalWidth = 0;
for(let i=0;i<list.length;i++){
totalWidth = totalWidth + list[i].offsetWidth; //所有列表元素的總寬度
}
for(let i=0;i<list.length;i++){
var _offset = totalWidth - box.clientWidth; //右邊的偏移量
list[i].addEventListener('click', function (e) {
for(let j=0;j<list.length;j++){
list[j].className = 'off'; //移除所有元素的樣式
}
list[i].className = 'on'; //給點(diǎn)擊的元素添加樣式
var offset =totalWidth - (Math.abs(listBox.offsetLeft) + box.clientWidth) + 100; //右邊的偏移量 = 所有元素寬度之和 - (ul容器的左偏移量 + 父容器的寬度)
if(e.pageX > width && offset > 0){ //點(diǎn)擊右側(cè)并且右側(cè)的偏移量大于0,左滑。
listBox.style.left = (listBox.offsetLeft-200) + 'px';
}else if(e.pageX > width && offset > 200){ //臨界位置,,右側(cè)滾動(dòng)到末尾
listBox.style.left = -_offset + 'px';
}
if(e.pageX < width && listBox.offsetLeft < -200) { //點(diǎn)擊左側(cè)并且左側(cè)的偏移量小于0,左滑。
listBox.style.left = (listBox.offsetLeft + 200) + 'px';
}else if(e.pageX < width && listBox.offsetLeft < 0){ //臨界位置,左側(cè)滾到開始的位置
listBox.style.left = 0
}
});
}
點(diǎn)擊如下所示:

還有些不完善的地方,求各位大神指正。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 利用Js+Css實(shí)現(xiàn)折紙動(dòng)態(tài)導(dǎo)航效果實(shí)例源碼
- JS+CSS實(shí)現(xiàn)鼠標(biāo)滑過時(shí)動(dòng)態(tài)翻滾的導(dǎo)航條效果
- javascript實(shí)現(xiàn)的鼠標(biāo)懸停時(shí)動(dòng)態(tài)翻滾的導(dǎo)航條
- JS實(shí)現(xiàn)移動(dòng)端可折疊導(dǎo)航菜單(現(xiàn)代都市風(fēng))
- JS無限級(jí)導(dǎo)航菜單實(shí)現(xiàn)方法
- vuejs 切換導(dǎo)航條高亮(路由菜單高亮)的方法示例
- 原生JS實(shí)現(xiàn)導(dǎo)航下拉菜單效果
- 如何使用wheelnav.js構(gòu)建酷炫的動(dòng)態(tài)導(dǎo)航菜單
相關(guān)文章
微信小程序?qū)崿F(xiàn)Timeline時(shí)間線效果
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)Timeline時(shí)間線效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05
前端報(bào)錯(cuò)Failed?to?resolve?component:?smile-outlined?If?thi
這篇文章主要為大家介紹了前端報(bào)錯(cuò)?Failed?to?resolve?component:?smile-outlined?If?this?is?a?native?custom?的問題分析解決,有需要的朋友可以借鑒參考下2023-06-06
javascript中style.left和offsetLeft的用法說明
本篇文章主要是對(duì)javascript中style.left和offsetLeft的用法進(jìn)行了說明介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助2014-03-03
移動(dòng)端利用H5實(shí)現(xiàn)壓縮圖片上傳功能
這篇文章主要為大家詳細(xì)介紹了移動(dòng)端利用H5實(shí)現(xiàn)壓縮圖片上傳功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03
JS document對(duì)象簡(jiǎn)單用法完整示例
這篇文章主要介紹了JS document對(duì)象簡(jiǎn)單用法,結(jié)合完整實(shí)例形式詳細(xì)分析了JS document對(duì)象獲取、輸出、節(jié)點(diǎn)調(diào)用等相關(guān)操作技巧,需要的朋友可以參考下2020-01-01
jQuery ajax(復(fù)習(xí))—Baidu ajax request分離版
你沒有看錯(cuò)標(biāo)題,本文的確是在講Baidu ajax,不過是很久很久以前的版本了,我們先分析一段簡(jiǎn)單的ajax代碼,來自早期的百度七巧板項(xiàng)目通過這個(gè)來先復(fù)習(xí)一遍ajax的知識(shí)2013-01-01

