国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

vue.js實現回到頂部動畫效果

2019-11-19 11:05:44
字體:
來源:轉載
供稿:網友

最近使用vue.js做了幾個頁面,其中有一個回到頂部的動畫效果記錄下。

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, // 返回頂部所需時間 backSeconds : 100, // 往下滑動多少顯示返回頂部(單位: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); } }});

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 郸城县| 六枝特区| 闻喜县| 阿拉善左旗| 沛县| 兴安盟| 香港 | 永春县| 六枝特区| 长沙县| 东方市| 南充市| 永安市| 石柱| 兰溪市| 蕉岭县| 伊金霍洛旗| 梁河县| 开封市| 高青县| 武宁县| 泽普县| 鞍山市| 永济市| 遵义市| 洛宁县| 杭州市| 莱西市| 吉林省| 米林县| 惠东县| 娱乐| 永新县| 孟津县| 共和县| 含山县| 开化县| 凤阳县| 嘉兴市| 桃园市| 大化|