vue實(shí)現(xiàn)一個(gè)滾動(dòng)條樣式

起初是想修改瀏覽器滾動(dòng)條樣式來(lái)達(dá)到效果
但是查閱了資料 瀏覽器滾動(dòng)條不能修改寬度與位置
沒(méi)辦法只能自己寫(xiě)
首先是滾動(dòng)條樣式
<div class="scrollBar" v-if="roleList.length > 5">
<div
class="box"
@mousedown="move"
v-bind:style="{ width: activewidth + 'px' }"
></div>
</div>
樣式
.scrollBar {
width: 500px;
height: 6px;
background: #d5dbf5;
margin: 0 auto;
margin-top: 72px;
border-radius: 4px;
position: relative;
.box {
width: 30px;
height: 100%;
background: #fff;
border-radius: 4px;
position: absolute;
left: 0;
}
.box:hover {
cursor: pointer;
}
}
滾動(dòng)區(qū)域的樣式這里就不寫(xiě)了
1 首先是滾動(dòng)條滑塊的寬度
mounted() {
//滾動(dòng)區(qū)域?qū)挾? 我這里是遍歷的user列表 所以我拿到列表的長(zhǎng)度*每個(gè)li的寬度即為總寬度
let bgWidth = this.$refs.liList.clientWidth * this.roleList.length;
//可視區(qū)域?qū)挾? 1065 這個(gè)就是上圖中白色背景盒子的寬度
//滑塊寬度 500為滾動(dòng)條寬度 計(jì)算這個(gè)寬度是為了拿到滑塊可以滑動(dòng)的距離 這個(gè)下面會(huì)說(shuō)到
this.activewidth = 500 * (1065 / bgWidth);
},
2 給滑塊添加鼠標(biāo)事件
move(e) {
//獲取目標(biāo)元素
let odiv = e.target;
// ScrollArea
//算出鼠標(biāo)相對(duì)元素的位置
let disX = e.clientX - odiv.offsetLeft;
//滾動(dòng)條可以滾動(dòng)的距離
let viewArea = 500 - this.activewidth;
//滾動(dòng)區(qū)域?qū)挾?
let bgWidth = this.$refs.liList.clientWidth * this.roleList.length;
document.onmousemove = (e) => {
//鼠標(biāo)按下并移動(dòng)的事件
//用鼠標(biāo)的位置減去鼠標(biāo)相對(duì)元素的位置,得到元素的位置
let left = e.clientX - disX;
//left < 0 表示滑塊已經(jīng)到最左邊
//或者left > viewArea 表示滑塊到最右邊
if (left < 0 || left > viewArea) {
//console.log("到頭了");
//這個(gè)時(shí)候要清空事件 不然滑塊就劃出滾動(dòng)條區(qū)域了
document.onmousemove = null;
} else {
//滑塊的滑動(dòng)距離
odiv.style.left = left + "px";
//滾動(dòng)區(qū)域的滑動(dòng)距離 = 滾動(dòng)區(qū)域?qū)挾?(滑塊滑動(dòng)的距離/500)
this.$refs.ScrollArea.style.left =
"-" + bgWidth * left / 500 + "px";
}
};
document.onmouseup = (e) => {
document.onmousemove = null;
document.onmouseup = null;
};
},
到此這篇關(guān)于vue實(shí)現(xiàn)一個(gè)滾動(dòng)條樣式的文章就介紹到這了,更多相關(guān)vue實(shí)現(xiàn)滾動(dòng)條內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue自定義組件@click點(diǎn)擊失效問(wèn)題及解決
這篇文章主要介紹了vue自定義組件@click點(diǎn)擊失效問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
解決vue中對(duì)象屬性改變視圖不更新的問(wèn)題
下面小編就為大家分享一篇解決vue中對(duì)象屬性改變視圖不更新的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-02-02
vue登錄路由權(quán)限管理的項(xiàng)目實(shí)踐
在開(kāi)發(fā)Web應(yīng)用程序時(shí),常常需要進(jìn)行登錄驗(yàn)證和權(quán)限管理,本文主要介紹了vue登錄路由權(quán)限管理的項(xiàng)目實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04
在vue中對(duì)數(shù)組值變化的監(jiān)聽(tīng)與重新響應(yīng)渲染操作
這篇文章主要介紹了在vue中對(duì)數(shù)組值變化的監(jiān)聽(tīng)與重新響應(yīng)渲染操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07
前端不用跑項(xiàng)目vscode組件效果所見(jiàn)即所得
這篇文章主要為大家介紹了一款不用跑項(xiàng)目的vscode組件所見(jiàn)即所得效果的使用方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-04-04
Vue2中無(wú)法監(jiān)聽(tīng)數(shù)組和對(duì)象的某些變化問(wèn)題
這篇文章主要介紹了Vue2中無(wú)法監(jiān)聽(tīng)數(shù)組和對(duì)象的某些變化問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08

