av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

vue實(shí)現(xiàn)全屏滾動(dòng)效果(非fullpage.js)

瀏覽:95日期:2023-02-02 14:52:31

本文實(shí)例為大家分享了vue實(shí)現(xiàn)全屏滾動(dòng)效果(的具體代碼,供大家參考,具體內(nèi)容如下

是什么

網(wǎng)頁(yè)的一個(gè)頁(yè)面占據(jù)一屏的寬高,多個(gè)頁(yè)面上下或者左右拼接在一起。當(dāng)滑動(dòng)鼠標(biāo)滾輪,或點(diǎn)擊導(dǎo)航按鈕時(shí),可以平滑到對(duì)應(yīng)的頁(yè)面。

此次只實(shí)現(xiàn)鼠標(biāo)滾動(dòng)

實(shí)現(xiàn)原理

使用mousewheel , DOMMouseScroll(火狐用)監(jiān)聽(tīng)鼠標(biāo)滾動(dòng)事件,當(dāng)鼠標(biāo)上下的滾動(dòng)的時(shí)候,當(dāng)前的頁(yè)面transformY(屏高)或者transformX(屏寬)

代碼實(shí)現(xiàn)

HTML

<template> <div ref='fullPage'> <div ref='fullPageContainer' @mousewheel='mouseWheelHandle' //監(jiān)聽(tīng)鼠標(biāo)事件 @DOMMouseScroll='mouseWheelHandle' // 監(jiān)聽(tīng)鼠標(biāo)事件 > <div class='section section1'>1</div> <div class='section section2'>2</div> <div class='section section3'>3</div> <div class='section section4'>4</div> </div> </div></template>

JS

<script>export default { name: 'Home', data() { return { fullpage: { current: 1, // 當(dāng)前的頁(yè)面編號(hào) isScrolling: false, // 是否在滾動(dòng),是為了防止?jié)L動(dòng)多頁(yè),需要通過(guò)一個(gè)變量來(lái)控制是否滾動(dòng) deltaY: 0 // 返回鼠標(biāo)滾輪的垂直滾動(dòng)量,保存的鼠標(biāo)滾動(dòng)事件的deleteY,用來(lái)判斷是往下還是往上滾 } }; }, methods: { next() { // 往下切換 let len = 4; // 頁(yè)面的個(gè)數(shù) if (this.fullpage.current + 1 <= len) { // 如果當(dāng)前頁(yè)面編號(hào)+1 小于總個(gè)數(shù),則可以執(zhí)行向下滑動(dòng) this.fullpage.current += 1; // 頁(yè)面+1 this.move(this.fullpage.current); // 執(zhí)行切換 } }, pre() {// 往上切換 if (this.fullpage.current - 1 > 0) { // 如果當(dāng)前頁(yè)面編號(hào)-1 大于0,則可以執(zhí)行向下滑動(dòng) this.fullpage.current -= 1;// 頁(yè)面+1 this.move(this.fullpage.current);// 執(zhí)行切換 } }, move(index) { this.fullpage.isScrolling = true; // 為了防止?jié)L動(dòng)多頁(yè),需要通過(guò)一個(gè)變量來(lái)控制是否滾動(dòng) this.directToMove(index); //執(zhí)行滾動(dòng) setTimeout(() => { //這里的動(dòng)畫(huà)是1s執(zhí)行完,使用setTimeout延遲1s后解鎖 this.fullpage.isScrolling = false; }, 1010); }, directToMove(index) { let height = this.$refs['fullPage'].clientHeight; //獲取屏幕的寬度 let scrollPage = this.$refs['fullPageContainer']; // 獲取執(zhí)行tarnsform的元素 let scrollHeight; // 計(jì)算滾動(dòng)的告訴,是往上滾還往下滾 scrollHeight= -(index - 1) * height + 'px'; scrollPage.style.transform = `translateY(${scrollHeight})`; this.fullpage.current = index; }, mouseWheelHandle(event) { // 監(jiān)聽(tīng)鼠標(biāo)監(jiān)聽(tīng) // 添加冒泡阻止 let evt = event || window.event; if (evt.stopPropagation) { evt.stopPropagation(); } else { evt.returnValue = false; } if (this.fullpage.isScrolling) { // 判斷是否可以滾動(dòng) return false; } let e = event.originalEvent || event; this.fullpage.deltaY = e.deltaY || e.detail; // Firefox使用detail if (this.fullpage.deltaY > 0) { this.next(); } else if (this.fullpage.deltaY < 0) { this.pre(); } } }};</script>

CSS

<style scoped>.fullPage{ height: 100%;//一定要設(shè)置,保證占滿 overflow: hidden;//一定要設(shè)置,多余的先隱藏 background-color: rgb(189, 211, 186);}.fullPageContainer{ width: 100%; height: 100%; transition: all linear 0.5s;}.section { width: 100%; height: 100%; background-position: center center; background-repeat: no-repeat;}.section1 { background-color: rgb(189, 211, 186); background: url('./assets/intro-bg.jpg');}.section1 .secction1-content { color: #fff; text-align: center; position: absolute; top: 40%; right: 0; left: 0;}.secction1-content h1 { font-size: 40px; padding-bottom: 30px;}.secction1-content p { font-size: 20px;}.section2 { background-color: rgb(44, 48, 43);}.section3 { background-color: rgb(116, 104, 109);}.section4 { background-color: rgb(201, 202, 157);}</style>

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 久久亚洲视频网 | 日韩一级免费 | 欧美在线综合 | 亚洲一区二区三区在线视频 | 日韩欧美中文字幕在线观看 | 亚洲国产精品va在线看黑人 | 丝袜一区二区三区 | 亚洲精品视频三区 | 久久精品二区亚洲w码 | 精品欧美一区二区三区精品久久 | 国产欧美一区二区三区国产幕精品 | av在线成人 | 久久99精品久久久久久青青日本 | 日韩一级 | 欧美日韩在线不卡 | 日本福利在线观看 | 免费看91| 亚洲成人精品免费 | 亚洲人成人一区二区在线观看 | 国产精品一区一区 | 欧美一级欧美一级在线播放 | 国产精品夜夜春夜夜爽久久电影 | 91精品国产一区二区三区 | 欧美黄色片 | 91精品久久久久久久99 | 日日碰狠狠躁久久躁婷婷 | 欧美性猛交 | av片在线观看 | 噜噜噜色网 | 久久国产精品精品 | 国产不卡一区在线观看 | 午夜免费观看网站 | 中文字幕日韩一区 | 国产精品久久久久不卡 | 精品熟人一区二区三区四区 | 在线播放一区二区三区 | 精品一区免费 | 亚洲欧洲色视频 | 中文字幕在线视频网站 | 国产免费拔擦拔擦8x高清 | 一级片aaa |