码迷,mamicode.com
首页 > Web开发 > 详细

如何不用 transition 和 animation 也能做网页动画

时间:2018-11-21 15:47:04      阅读:189      评论:0      收藏:0      [点我收藏+]

标签:视频   一个   get   mba   sla   load   图片   image   otto   

技术分享图片

效果预览

在线演示

按下右侧的“点击预览”按钮可以在当前页面预览,点击链接可以全屏预览。


https://codepen.io/comehope/pen/BxbQJj


可交互视频教程


此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。


请用 chrome, safari, edge 打开观看。


https://scrimba.com/c/crvq8hq


源代码下载


本地下载

每日前端实战系列的全部源代码请从 github 下载:


https://github.com/comehope/front-end-daily-challenges


代码解读


定义 dom,一个容器中包含 4 个子元素,每个子元素的内容就是一堆斜线:

<div class="frame">
    <div class="wall top"><marquee>////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////</marquee></div>
    <div class="wall right"><marquee>////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////</marquee></div>
    <div class="wall bottom"><marquee>////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////</marquee></div>
    <div class="wall left"><marquee>////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////</marquee></div>
</div>

居中显示:

body {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

定义容器尺寸:

.frame {
    width: 100vmin;
    height: 100vmin;
    background-color: whitesmoke;
}

隐藏超出容器的内容:

.wall {
    overflow: hidden;
}

把 4 个元素向四个方向旋转,互相垂直:

.wall {
    transform-origin: 0 0;
}

.wall.top {
    transform: rotate(0deg);
}

.wall.right {
    transform: rotate(90deg);
}

.wall.bottom {
    transform: rotate(180deg);
}

.wall.left {
    transform: rotate(270deg);
}

定位它们,形成一个正方形:

.frame {
    position: relative;
}

.wall {
    position: absolute;
    width: 100%;
}

.wall.top {
    top: 0;
    left: 0;
}

.wall.right {
    top: 0;
    left: 100%;
}

.wall.bottom {
    top: 100%;
    left: 100%;
}

.wall.left {
    top: 100%;
    left: 0;
}

对 4 个元素进行 3d 旋转:

.frame {
    perspective: 40vmin;
}

.wall.top {
    transform: rotate(0deg) rotateX(-90deg);
}

.wall.right {
    transform: rotate(90deg) rotateX(-90deg);
}

.wall.bottom {
    transform: rotate(180deg) rotateX(-90deg);
}

.wall.left {
    transform: rotate(270deg) rotateX(-90deg);
}

把斜线加粗、放大:

.wall {
    font-size: 75vmin;
    font-weight: bold;
}

最后,把 dom 中的斜线用 <marquee> 标签包围起来:

&lt;div class="frame"&gt;
    &lt;div class="wall top"&gt;&lt;marquee&gt;////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////&lt;/marquee&gt;&lt;/div&gt;
    &lt;div class="wall right"&gt;&lt;marquee&gt;////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////&lt;/marquee&gt;&lt;/div&gt;
    &lt;div class="wall bottom"&gt;&lt;marquee&gt;////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////&lt;/marquee&gt;&lt;/div&gt;
    &lt;div class="wall left"&gt;&lt;marquee&gt;////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////&lt;/marquee&gt;&lt;/div&gt;
&lt;/div&gt;

大功告成!

原文地址:https://segmentfault.com/a/1190000014964220

如何不用 transition 和 animation 也能做网页动画

标签:视频   一个   get   mba   sla   load   图片   image   otto   

原文地址:https://www.cnblogs.com/datiangou/p/9994297.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!