文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

css3代码如何实现多个元素依次显示效果

2023-07-04 23:35

关注

这篇文章主要介绍“css3代码如何实现多个元素依次显示效果”,在日常操作中,相信很多人在css3代码如何实现多个元素依次显示效果问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”css3代码如何实现多个元素依次显示效果”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

在css3中,我们使用animation与keyframes结合,可以给元素添加各种各样的动画效果。具体的动画,在keyframes中定义,在animation中使用。例如可以定义一个从上飞入的动画效果。

@keyframes topIn {  from { transform: translateY(-50px) }  to { transform: translateY(0px) }}

并在目标元素中通过animation来使用动画。

<div class="target topIn"></div>.topIn {  animation: topIn 1s ease;}

这样,当元素第一次渲染进入DOM时,就会有一个从上到下的位移动画效果。当然,这种效果并不是我们想要的。往往我们还在在动画上加上一个透明度从0到1的渐变。

@keyframes topIn {  from {     transform: translateY(-50px);    opacity: 0;   }  to {     transform: translateY(0px);    opacity: 1;   }}

我们还希望能够控制元素的显示时机应该怎么办?简单一点的办法就是在需要动画效果展示时,才给目标元素添加控制动画的class样式。

btn.addEventListener('click', function() {  document.querySelector('.target').classList.add('topIn');}, !1);

但是这样做有一个问题。我相信实践过的朋友都已经发现过的。我们期望元素在入场之前,是处于看不见的状态。但是仅仅只是上面的做法,动画开始前元素是能够被看见的。那么应该怎么办?

我们可以很简单的想到,给元素添加 display: none 或者 visibility: hidden 。但是由于 display: none 之后,元素是不占位的。因此如果这样的话,会导致页面布局出现混乱。所以我们在开始之前,给元素添加一个新的class。

.aninode {  visibility: hidden;}

并且添加一个新的class让元素显示出来。

.animated .aninode {  visibility: visible;}

控制动画效果的class也在css上进行一些调整。

.animated .topIn {  animation: topIn 1s ease;}

这样做的好处是,我们只需要在class中添加一个 animated ,就能够达到我们的效果。实例demo完整代码如下:

<div class="container">  <div class="target aninode leftIn"></div>  <button class="btn show">show</button>  <button class="btn hide">hide</button></div>.container {  width: 100px;  margin: 0 auto;}.aninode {  visibility: hidden;}.animated .aninode {  visibility: visible;}.target {  width: 100px;  height: 100px;  background: orange;  border-radius: 4px;  margin: 20px 0;}.animated .topIn {  animation: topIn 1s ease;}.animated .leftIn {  animation: leftIn 1s ease;}.btn {  width: 100px;  height: 30px;  border: 1px solid #ccc;  outline: none;  transition: 0.1s;}.btn:active {  border: none;  background: orange;  color: #fff;}@keyframes topIn {  from {     transform: translateY(-50px);    opacity: 0;   }  to {     transform: translateY(0px);    opacity: 1;   }}@keyframes leftIn {  from {     transform: translateX(-50px);    opacity: 0;   }  to {     transform: translateX(0px);    opacity: 1;   }}var show = document.querySelector('.show');var hide = document.querySelector('.hide');var container = document.querySelector('.container');show.addEventListener('click', function() {  container.classList.add('animated');}, !1);hide.addEventListener('click', function() {  container.classList.remove('animated');}, !1);

Demo显示如下:

See the Pen <a href='https://codepen.io/yangbo5207/pen/NXKrPg/'>NXKrPg</a> by Ormie (<a href='https://codepen.io/yangbo5207'>@yangbo5207</a>) on <a href='https://codepen.io'>CodePen</a>.

codepen demo 地址

但是这样离我们想要的效果好像还差一点点。继续思考。首先想要后面的元素比前一个元素晚一点出现,那么肯定是要控制延迟时间,我们就必须有许多设置延迟时间的class。

.delay200 {    animation-delay: 200ms;    animation-fill-mode: backwards!important;}.delay400 {    animation-delay: 400ms;    animation-fill-mode: backwards!important;}.delay600 {    animation-delay: 600ms;    animation-fill-mode: backwards!important;}.delay800 {    animation-delay: 800ms;    animation-fill-mode: backwards!important;}

animation-fill-mode: backwards!important; 的目的是为了元素在出现之前,保持透明度为0的状态。防止当添加 animated 之后元素直接出现了。

加 !important 是为了防止在新的class中使用animation简写时对 animation-fill-mode 的属性进行覆盖改写。如果此处不写 !important 的话,那么在 topIn 这样的动画class中就不能使用简写形式。

这样之后,我们只需要在css中添加上上述代码,并对html做一些改动,就能够实现我们想要的效果了。

See the Pen <a href='https://codepen.io/yangbo5207/pen/mpbEEE/'>mpbEEE</a> by Ormie (<a href='https://codepen.io/yangbo5207'>@yangbo5207</a>) on <a href='https://codepen.io'>CodePen</a>.

codepen demo 地址

完整代码如下:

<div class="container">  <div class="targets aninode">      <div class="item leftIn">春晓</div>      <div class="item leftIn delay200">春眠不觉晓</div>      <div class="item leftIn delay400">处处蚊子咬</div>      <div class="item leftIn delay600">夜来风雨声</div>      <div class="item leftIn delay800"><此处请留下你们的才华></div>  </div>  <button class="btn show">show</button>  <button class="btn hide">hide</button></div>.container {  width: 200px;  margin: 0 auto;}.aninode {  visibility: hidden;}.animated .aninode {  visibility: visible;}.targets {  margin: 20px 0;}.targets .item {    border: 1px solid #ccc;    margin: 10px 0;    line-height: 2;    padding: 2px 6px;    border-radius: 4px;}.animated .topIn {  animation: topIn 1s ease;}.animated .leftIn {  animation-name: leftIn;  animation-duration: 1s;}.btn {  width: 100px;  height: 30px;  border: 1px solid #ccc;  outline: none;  transition: 0.1s;}.btn:active {  border: none;  background: orange;  color: #fff;}@keyframes topIn {  from { transform: translateY(-50px) }  to { transform: translateY(0px) }}@keyframes leftIn {  from {     transform: translateX(-50px);    opacity: 0;   }  to {     transform: translateX(0px);    opacity: 1;   }}.delay200 {    animation-delay: 200ms;    animation-fill-mode: backwards!important;}.delay400 {    animation-delay: 400ms;    animation-fill-mode: backwards!important;}.delay600 {    animation-delay: 600ms;    animation-fill-mode: backwards!important;}.delay800 {    animation-delay: 800ms;    animation-fill-mode: backwards!important;}var show = document.querySelector('.show');var hide = document.querySelector('.hide');var container = document.querySelector('.container');show.addEventListener('click', function() {  container.classList.add('animated');}, !1);hide.addEventListener('click', function() {  container.classList.remove('animated');}, !1);

我们发现js的逻辑并没有发生任何改变。仍然仅仅只是在合适的位置添加/删除animated。

彩蛋:

在实践中我们还会遇到一个比较麻烦的事儿。就是延迟class的编写。我们可能并不知道会使用到那些时差,有多少个元素会使用到,如果都用手来写的话,重复工作确实太过麻烦。因此我们可以使用js动态插入。代码如下:

const styleSheet = getSheet();var delay = 100;while (delay < 10000) {    styleSheet.insertRule(`.animated .delay${delay}{ animation-delay: ${delay}ms; animation-fill-mode: backwards; }`, styleSheet.cssRules.length);    delay += delay < 3000 ? 100 : 1000;}function getSheet() {    var sheets = document.styleSheets;    var len = sheets.length;    for(var i = 0; i <= len; i++) {        var sheet = sheets.item(i);        try {            if (sheet.cssRules) {                return sheet;            }        } catch(e) {}     }    var style = document.createElement('style');    style.type = "text/css";    document.getElementsByTagName('head')[0].appendChild(style);    return style.sheet;}

css的基本语法是什么

css的基本语法是:

1、css规则由选择器和一条或多条声明两个部分构成;

2、选择器通常是需要改变样式的HTML元素;

3、每条声明由一个属性和一个值组成;

4、属性和属性值被冒号分隔开。

到此,关于“css3代码如何实现多个元素依次显示效果”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯