手搓页面预加载
发表于更新于
阅读量:       成都
手搓页面预加载
Breezli页面预加载
本文实现了
1.预加载转圈动画+加载完毕销毁组件
2.开屏蒙版特效(after资源加载完毕)
3.主页背景图模糊+缩放动画(after资源加载完毕)
代码结构
HTML
| 12
 3
 4
 5
 6
 7
 
 | <div class="svg">
 <div class="container">
 <div class="circle"></div>
 <span>loding......</span>
 </div>
 </div>
 
 | 
门板
| 12
 3
 
 | <div class="left"></div>
 <div class="right"></div>
 
 | 
主页面
| 12
 
 | <img class="page" src="https://haowallpaper.com/link/common/file/previewFileImg/718a61f6cd6efa803ca87eb743fec045718a61f6cd6efa803ca87eb743fec045" alt="" />
 
 | 
JS
预加载工具
| 1
 | <script src="http://libs.baidu.com/jquery/1.8.3/jquery.min.js"></script>
 | 
动态更新
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 
 | <!-- JS动态更新 --><script>
 let left = document.querySelector('.left')
 let right = document.querySelector('.right')
 let page = document.querySelector('.page')
 
 $(window).on('load', function () {
 $('.svg').animate(
 {
 opacity: 0,
 },
 500
 )
 setTimeout(function () {
 $('.svg').remove()
 
 setTimeout(function () {
 
 left.style.transform = `translateX(-60vw)`
 right.style.transform = `translateX(60vw)`
 
 page.style.animation = `blur-to-clear 2s cubic-bezier(0.62, 0.21, 0.25, 1) 0s 1
 normal backwards running,scale 2s cubic-bezier(0.62, 0.21, 0.25, 1) 0s 1 both`
 }, 200)
 }, 500)
 })
 </script>
 
 | 
CSS
全局配置
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 
 | * {margin: 0;
 padding: 0;
 box-sizing: border-box;
 }
 body {
 margin: 0;
 padding: 0;
 
 overflow: hidden;
 }
 
 | 
动画函数
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 
 | @keyframes rotate {
 0% {
 transform: rotate(0deg);
 }
 100% {
 transform: rotate(360deg);
 }
 }
 
 
 @keyframes blur-to-clear {
 0% {
 filter: blur(35px);
 }
 100% {
 filter: blur(0px);
 }
 }
 
 @keyframes scale {
 0% {
 transform: scale(1.5);
 }
 100% {
 transform: scale(1);
 }
 }
 
 | 
包裹加载的样式svg(loding后去除)
| 12
 3
 4
 5
 6
 7
 
 | .svg {z-index: 999;
 position: absolute;
 width: 100vw;
 height: 100vh;
 background-color: black;
 }
 
 | 
主页背景
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 
 | img.page {position: relative;
 display: block;
 margin: 0;
 padding: 0;
 box-sizing: border-box;
 width: 100vw;
 height: 100vh;
 min-width: 1080px;
 transition: opacity 1s;
 
 
 
 
 }
 
 | 
加载圆圈样式
详细拆分见文章“页面circle加载动画”
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 
 | .container {position: relative;
 width: 100%;
 height: 100%;
 display: flex;
 justify-content: center;
 align-items: center;
 
 background-color: rgb(30, 30, 30);
 }
 .circle {
 position: absolute;
 width: 200px;
 height: 200px;
 display: flex;
 justify-content: center;
 align-items: center;
 border-radius: 50%;
 
 background-image: linear-gradient(
 0deg,
 rgb(0, 255, 170),
 rgb(0, 17, 255),
 rgb(255, 0, 255)
 );
 
 animation: rotate 2s linear infinite;
 }
 
 .circle::before {
 content: '';
 position: absolute;
 width: 200px;
 height: 200px;
 border-radius: 50%;
 
 background-image: linear-gradient(
 0deg,
 rgb(0, 255, 170),
 rgb(0, 17, 255),
 rgb(255, 0, 255)
 );
 filter: blur(35px);
 }
 
 .circle::after {
 content: '';
 position: absolute;
 width: 180px;
 height: 180px;
 border-radius: 50%;
 background-color: rgb(30, 30, 30);
 
 }
 span {
 position: absolute;
 color: rgb(255, 255, 255);
 }
 
 | 
开屏门板
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 
 | .left {z-index: 998;
 position: absolute;
 width: 50vw;
 height: 100vh;
 background-color: rgb(30, 30, 30);
 transition: transform 1s;
 transform-origin: center center;
 }
 .right {
 z-index: 998;
 position: absolute;
 width: 50vw;
 height: 100vh;
 left: 50vw;
 background-color: rgb(30, 30, 30);
 transition: transform 1s;
 transform-origin: center center;
 }
 
 |