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

简介: 效果预览在线演示按下右侧的“点击预览”按钮可以在当前页面预览,点击链接可以全屏预览。https://codepen.io/comehope/pen/BxbQJj可交互视频教程此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。

img_83f064469ce832442c09a4cbeb6bda1c.png

效果预览

在线演示

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


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

相关文章
|
6月前
|
前端开发 JavaScript
前端 css 经典:transition 过渡和 animation 动画
前端 css 经典:transition 过渡和 animation 动画
79 2
|
6月前
|
前端开发 UED
深入理解CSS过渡效果(Transition):提升网页动画体验
深入理解CSS过渡效果(Transition):提升网页动画体验
311 1
|
前端开发
CSS动画篇之404动画
CSS动画篇之404动画
148 0
CSS3动画属性之Animation
CSS3动画属性之Animation
101 0
|
前端开发
写个简单css动画,transition 和animate
写个简单css动画,transition 和animate
115 0
11、CSS3的动画效果(animation)
11、CSS3的动画效果(animation)
186 0
11、CSS3的动画效果(animation)
|
前端开发
2、CSS动画——拳皇动画实现
2、CSS动画——拳皇动画实现
123 0
2、CSS动画——拳皇动画实现
|
机器学习/深度学习
CSS3动画属性 animation详解(看完就会)
CSS3动画属性 animation详解(看完就会)
245 0
CSS3动画属性 animation详解(看完就会)
|
前端开发 JavaScript API
transition过渡&动画
《Vue实战》笔记
93 0
|
前端开发 JavaScript
前端笔记:css3动画transition和animation
前端笔记:css3动画transition和animation
128 0