vue點(diǎn)擊導(dǎo)航頁面實(shí)現(xiàn)自動滾動到特定位置
效果預(yù)覽
npm i element-ui -S
下載安裝element組件庫,導(dǎo)航我們使用element組件庫中的樣式
type="primary"剛好作為我們導(dǎo)航激活后的樣式
省去了我們寫樣式的時(shí)間
到 main.js文件中全局引入element組件
import ElementUI from 'element-ui'; import 'element-ui/lib/theme-chalk/index.css'; Vue.use(ElementUI);
代碼實(shí)現(xiàn)
<!-- 為每一個(gè)按鈕 添加點(diǎn)擊事件 用來作為按鈕的切換 我們將所有的按鈕導(dǎo)航裝到 一個(gè)div中,給這個(gè)div添加點(diǎn)擊事件就可以了(不知道為什么的小伙伴可以去看一下事件冒泡) 由于進(jìn)入頁面要有默認(rèn)激活項(xiàng),我們將data屬性中的active賦值為1,就可以了,每次點(diǎn)擊,只需要通過 訪問dataset中的屬性動態(tài)的賦值給active就可以實(shí)現(xiàn)切換啦 --> <div @click="dbclick"> <el-button :type="active=='1'?'primary':''" data-index="1">新建</el-button> <el-button :type="active=='2'?'primary':''" data-index="2">銷毀</el-button> <el-button :type="active=='3'?'primary':''" data-index="3">轉(zhuǎn)辦</el-button> <el-button :type="active=='4'?'primary':''" data-index="4">發(fā)送</el-button> </div> <script> export default{ data() { return { active: "1" } }, } </script>
<!-- 接下來我們定義內(nèi)容展示部分,用一個(gè)大的盒子將其包裹,然后給與每一個(gè)子div不同的id,到后期我們會 使用到,本人比較懶散,內(nèi)容呢直接在這里循環(huán)了50次,以此來撐開盒子高度 --> <div class="height"> <div id="newview" ref="newview"> <span v-for="(item,index) in 50" :key="index" style="background:whitesmoke;">這是新建內(nèi)容</span> </div> <br><br><br><br><br><br><br><br><br><br><br><br><br><br><br> <div id="distory"> <span v-for="(item,index) in 50" :key="index" style="background:yellowgreen;">這是銷毀內(nèi)容</span> </div> <br><br><br><br><br><br><br><br><br><br><br><br><br><br><br> <div id="turn"> <span v-for="(item,index) in 50" :key="index" style="background:pink;">這是轉(zhuǎn)辦內(nèi)容</span> </div> <br><br><br><br><br><br><br><br><br><br><br><br><br><br><br> <div id="contantsend"> <span v-for="(item,index) in 50" :key="index" style="background:yellow;">這是發(fā)送內(nèi)容</span> </div> <br><br><br><br><br><br><br><br><br><br><br><br><br><br><br> </div> <script> export default { methods: { dbclick(e) { this.active=e.target.dataset.index // scrollIntoView 方法為滾動到指定元素位置 所以為了得到滾動元素的位置 // 為每一個(gè)元素添加了id 當(dāng)然初了id還可以使用ref為元素綁定值,通過this.$refs獲取 // 看您的喜好,想用那種都行 if(e.target.dataset.index==1){ // document.getElementById("newview").scrollIntoView({ // block: 'start', // behavior: 'smooth' //}) this.$refs.newview.scrollIntoView({ block: 'start', behavior: 'smooth'// 代表平滑滾動 }) } if(e.target.dataset.index==2){ document.getElementById("distory").scrollIntoView({ block: 'start', behavior: 'smooth' }) } if(e.target.dataset.index==3){ document.getElementById("turn").scrollIntoView({ block: 'start', behavior: 'smooth' }) } if(e.target.dataset.index==4){ document.getElementById("contantsend").scrollIntoView({ block: 'start', behavior: 'smooth' }) } console.log("觸發(fā)事件",e.target.dataset.index); } } } </script>
整體代碼
<template> <div> <div @click="dbclick"> <el-button :type="active=='1'?'primary':''" data-index="1">新建</el-button> <el-button :type="active=='2'?'primary':''" data-index="2">銷毀</el-button> <el-button :type="active=='3'?'primary':''" data-index="3">轉(zhuǎn)辦</el-button> <el-button :type="active=='4'?'primary':''" data-index="4">發(fā)送</el-button> </div> <div class="height"> <div id="newview" ref="newview"> <span v-for="(item,index) in 50" :key="index" style="background:whitesmoke;">這是新建內(nèi)容</span> </div> <br><br><br><br><br><br><br><br><br><br><br><br><br><br><br> <div id="distory"> <span v-for="(item,index) in 50" :key="index" style="background:yellowgreen;">這是銷毀內(nèi)容</span> </div> <br><br><br><br><br><br><br><br><br><br><br><br><br><br><br> <div id="turn"> <span v-for="(item,index) in 50" :key="index" style="background:pink;">這是轉(zhuǎn)辦內(nèi)容</span> </div> <br><br><br><br><br><br><br><br><br><br><br><br><br><br><br> <div id="contantsend"> <span v-for="(item,index) in 50" :key="index" style="background:yellow;">這是發(fā)送內(nèi)容</span> </div> <br><br><br><br><br><br><br><br><br><br><br><br><br><br><br> </div> </div> </template>
<script> export default { data() { return { active: "1" } }, methods: { dbclick(e) { this.active=e.target.dataset.index if(e.target.dataset.index==1){ this.$refs.newview.scrollIntoView({ block: 'start', behavior: 'smooth' }) } if(e.target.dataset.index==2){ document.getElementById("distory").scrollIntoView({ block: 'start', behavior: 'smooth' }) } if(e.target.dataset.index==3){ document.getElementById("turn").scrollIntoView({ block: 'start', behavior: 'smooth' }) } if(e.target.dataset.index==4){ document.getElementById("contantsend").scrollIntoView({ block: 'start', behavior: 'smooth' }) } console.log("觸發(fā)事件",e.target.dataset.index); } } } </script>
<style lang="scss" scoped> .height{ width: 30%; height:500px; margin: auto; background-color: bisque; word-break: break-all; overflow-y: scroll; // 垂直方向滾動條 } </style>
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue項(xiàng)目打包之后在本地運(yùn)行的實(shí)現(xiàn)方法
這篇文章主要介紹了vue項(xiàng)目打包之后在本地運(yùn)行的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07vue2.0開發(fā)實(shí)踐總結(jié)之疑難篇
這篇文章主要為大家總結(jié)了vue2.0開發(fā)實(shí)踐的疑難,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12Vue + Webpack + Vue-loader學(xué)習(xí)教程之功能介紹篇
這篇文章主要介紹了關(guān)于Vue + Webpack + Vue-loader功能介紹的相關(guān)資料,文中介紹的非常詳細(xì),相信對大家具有一定的參考價(jià)值,需要的朋友們下面來一起看看吧。2017-03-03vue實(shí)現(xiàn)大轉(zhuǎn)盤抽獎功能
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)大轉(zhuǎn)盤抽獎功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03vue2.0 下拉框默認(rèn)標(biāo)題設(shè)置方法
今天小編就為大家分享一篇vue2.0 下拉框默認(rèn)標(biāo)題設(shè)置方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08vue 使用鼠標(biāo)滾動加載數(shù)據(jù)的例子
今天小編就為大家分享一篇vue 使用鼠標(biāo)滾動加載數(shù)據(jù)的例子,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10vue修改數(shù)據(jù)的時(shí)候,表單值回顯不正確問題及解決
這篇文章主要介紹了vue修改數(shù)據(jù)的時(shí)候,表單值回顯不正確的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11