vue.js實(shí)現(xiàn)回到頂部動(dòng)畫效果
最近使用vue.js做了幾個(gè)頁面,其中有一個(gè)回到頂部的動(dòng)畫效果記錄下。
html如下:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>回到頂部</title> <META HTTP-EQUIV="pragma" CONTENT="no-cache"> <META HTTP-EQUIV="Cache-Control" CONTENT="no-cache"> <META HTTP-EQUIV="expires" CONTENT="0"> <meta http-equiv="X-UA-Compatible" content="IE=Edge"> <meta content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0" name="viewport"/> <link rel="stylesheet" href="./backTop.css" type="text/css"/> </head> <body> <div class="page">1</div> <div class="page">2</div> <div class="page">3</div> <div class="page">4</div> <div class="page">5</div> <div id="back-to-top" class="back-to-top" @click="backToTop" v-show="backTopShow" v-cloak> <span>回到</span> <span>頂部</span> </div> <script src="https://cdn.bootcss.com/vue/2.5.16/vue.min.js"></script> <script src="./backTop.js" type="text/javascript"></script> </body> </html>
backTop.css如下:
* { margin: 0px; padding: 0px; border: 0; } html, body { width: 100%; height: 100%; position: relative; background: #F2F2F2; overflow-x: hidden; overflow-y: auto; z-index: 1; } [v-cloak] { display: none; } .back-to-top { position: fixed; bottom: 5px; right: 20px; z-index: 100; border-radius: 5px; box-shadow: 0px 0px 2px #222; padding: 8px 10px; cursor: pointer; } .back-to-top:hover { background: #5AC4D1; } .back-to-top:hover span { color: white; } .back-to-top span { display: block; } .page { width: 100%; height: 400px; line-height: 400px; text-align: center; } .page:nth-child(odd) { background: white; }
backTop.js 如下:
var backTopVue = new Vue({ el : "#back-to-top", data : { //是否顯示回到頂部 backTopShow : false, // 是否允許操作返回頂部 backTopAllow : true, // 返回頂部所需時(shí)間 backSeconds : 100, // 往下滑動(dòng)多少顯示返回頂部(單位:px) showPx : 200 }, mounted : function() { window.addEventListener("scroll", this.backTopShowOperate, true); }, methods : { backTopShowOperate : function() { if (!this.backTopAllow) return; if (document.body.scrollTop > this.showPx) { this.backTopShow = true; } else { this.backTopShow = false; } }, backToTop : function() { if (!this.backTopAllow) return; this.backToTopShow = false; this.backTopAllow = false; var step = document.body.scrollTop / this.backSeconds; var backTopInterval = setInterval(function() { if (document.body.scrollTop > 0) { document.body.scrollTop -= step; } else { backTopVue.backTopAllow = true; clearInterval(backTopInterval); } }, 1); } } });
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue項(xiàng)目之學(xué)生管理系統(tǒng)實(shí)例詳解
這篇文章主要為大家詳細(xì)介紹了Vue項(xiàng)目之學(xué)生管理系統(tǒng)實(shí)例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03Vue通過for循環(huán)隨機(jī)生成不同的顏色或隨機(jī)數(shù)的實(shí)例
今天小編就為大家分享一篇Vue通過for循環(huán)隨機(jī)生成不同的顏色或隨機(jī)數(shù)的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11在vue框架下使用指令vue add element安裝element報(bào)錯(cuò)問題
這篇文章主要介紹了在vue框架下使用指令vue add element安裝element報(bào)錯(cuò)問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10解決vue3傳屬性時(shí)報(bào)錯(cuò)[Vue?warn]:Component?is?missing?template?or
這篇文章主要給大家介紹了關(guān)于解決vue3傳屬性時(shí)報(bào)錯(cuò)[Vue?warn]:Component?is?missing?template?or?render?function的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01解決betterScroll在vue中存在圖片時(shí),出現(xiàn)拉不動(dòng)的問題
今天小編就為大家分享一篇解決betterScroll在vue中存在圖片時(shí),出現(xiàn)拉不動(dòng)的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09Vue.js每天必學(xué)之計(jì)算屬性computed與$watch
Vue.js每天必學(xué)之計(jì)算屬性computed與$watch,為大家詳細(xì)講解計(jì)算屬性computed與$watch,感興趣的小伙伴們可以參考一下2016-09-09