常用CSS动画制作技巧及踩坑总结

1. CSS 3d透视

  • perspective 属性都是加给父元素的
  • transform-style:preserve-3d; 这个属性必须与transform一同使用,它使被转换的子元素保留其 3D 转换(即设置给父元素)
<!--这里是一个简单的透视的例子-->
<div class="door-border">
    <div class="door">我是门</div>
</div>
.door-border{
    border: 3px solid #aaa;
    width: 150px;
    height: 200px;
    perspective-origin: top;
    perspective: 200px;
    transform-style: preserve-3d;
}

.door-border .door{
    border: 1px solid brown;
    width: 100%;
    height: 100%;
    background-color: wheat;
    transform: rotate3d(0,1,0,45deg);
    transform-origin: left;
}

2. 元素本身有animation的属性时,transition 中在animation改变的属性会失效

    有一次制作一个类似于上下浮动的小波浪动画,动画从界面下方进入,由于同时设置的transition和animate对元素的同一个属性进行了更改,触发了此问题。

    解决办法:用伪元素或者嵌套父元素的方式将这两个行为分开 原理就是让transition和animation分别作用于不同的容器。

3. 表单标签没有伪元素

 img标签也没有伪元素

4. z-index失效

5. 抖动动画制作

  制作类似钱包抖动动画时,动画旋转角度可以从 -3deg -> 3deg -> -3deg -> 3deg 看起来比较顺畅

  如果是 6deg -> 0deg -> -6deg -> 0deg 会在 0deg 时,动画有卡顿现象(即不要把中间值设置为关键帧

6. 循环滚动动画原理

  原理(一):第一张与最后一张图完全相同,动画重复播放时没有时间间隔(纯CSS)

    a. transformX(0) -> transformX(-50%) 浏览器正常 移动端(Safari)不播放动画 页面隐藏后才播放 切换时图片会闪一下 原因未知

    b. transformX(0) -> transformX(-width(px)/2) 浏览器正常 移动端(Safari)播放动画 切换时图片会闪一下 原因未知

    c. 用 margin-left: 0 -> margin-left: -50%(用left亦可,二者百分比值都是基于父元素宽度计算的) 浏览器正常  移动端(Safari)播放动画会卡顿(可能是性能导致)

    目前采取c方案 控制卡顿在可接受范围内(由于书写循环动画时并没有考虑到浏览器重排带来的性能问题,故没有用绝对定位的元素来做测试)

    a、b方案的应用场景可适当斟酌

  原理(二):三张相同的图片 原理与轮播图类似 三张图无限轮播效果(主JS)

    PC端正常(要注意当前页面隐藏时取消定时器,否则会出bug),移动端未进行测试

7. 动画中需要用到background-image时,尽量用雪碧图

  在工作中,有一个两张图相互切换的效果,最开始是用keyframe from background-image to background-image (即来回切换两张图片)来实现背景切换的 效果非常差,还会触发离开页面一张图片失效的bug,后来更换雪碧图后,得到流畅的两张图切换的效果。

  

原文地址:https://www.cnblogs.com/Kuro-P/p/8678013.html

时间: 2024-07-30 11:49:53

常用CSS动画制作技巧及踩坑总结的相关文章

《CSS动画实用技巧》课程笔记

概述 这是我学习CSS动画实用技巧的课程笔记 常用动画属性--transition .change img{ display:block; width:300px; height:284px; opacity:0; -webkit-transform:translate(-100px,-100px); -webkit-transition:opacity 1s ease-in-out 0.5s,-webkit-transform 1s ease-in-out; transition: opaci

简析影视动画制作技巧

对于影视动画的制作技巧,每个人都有不同的见解.那么要做一个有吸引力的影视动画,大概是需要什么样的技巧,下面就来说明一下. 一.影视动画巧妙含蓄比喻,能够使高度的艺术进行浓缩. 影视动画制作在一定的程度上是为我们传达出一种思想,当然它可能是从角色的性格或者是从剧情上向我们展示的思想. 二.影视精辟地策划,适度地夸张. 影视动画的制作技术是精美,利用三维动画制作技术把影视动画的场景设计和人物的设计都很完美,在一定的程度上给予了角色动作或者是造型上的夸张感. 三.影视动画可以透彻剖析事理,深刻揭示本质

Css3之高级-7 Css动画(概述、关键帧、动画属性)

一.动画概述 动画概念 - 过渡属性只能模拟动画效果 - animation 属性可以制作类似 Flash 动画 - 通过关键帧控制动画的每一步 - 使元素从一种样式逐渐变化为另一种样式 - 实现复杂的动画效果 - 浏览器兼容性 - 最新版本支持良好 - Chrome 和 Safari 需要前缀 -webkit- - FireFox 需要前缀 -moz- - Opera 需要前缀 -o- 动画示例 - 声明动画 - 创建一个已命名的动画 - 使用 @keyframes 声明动画的关键帧 - 为元

CSS动画效果之animation

Y(^o^)Y css动画大乱弹之animation. 概述 什么是animation呢?在回答这个问题之前,先要说明什么叫做@keyframe(关键帧).@keyframe算是一个动画模板.在其中,可以使用百分比,如从0%到100%的任意值,分别在每个百分比中,加上不同的属性,从而让元素达到一种在不断变化的动画效果.这和我们制作flash动画一样,我们只需设计几个关键帧,系统就能生成动画啦! 一个@keyframe例子: 1 /*定义关键帧动画*/ 2 @keyframes myframe {

之后要接触更多代码管理的知识——2015踩坑有感

前言 学习是没有止境的,管理代码的能力也永远需要提高. 前几个月还觉得R语言,业务上要用的都学得七七八八了呢,这几个月在自家部门吭哧吭哧搞报表自动化时,各个坑一踩一个准,才明白写代码,懂得一点语言特性固然重要,弄一套科学地管理代码的方法,却是势在必行. 因此在这里总结一下这几个月来我踩过的种种坑,以及之后在查阅种种大神的经验,以及学软件工程这门课时看到的一些比较妥当的方法,算是这几个月的一个总结.2016年的时候,真的要多学学如何科学地管理代码,科学开发 请注意,因为我属于跨专业半路出家写代码,

CSS动画与GPU

写在前面 满世界的动画性能优化技巧,例如: 只允许改变transform.opacity,其它属性不要动,避免重新计算布局(reflow) 对动画元素应用transform: translate3d(0, 0, 0).will-change: transform等,开启硬件加速 动画元素尽量用fixed.absolute定位方式,避免reflow 对动画元素应用高一点的z-index,减少复合层数量 ...其它可能有用的规则 那么问题是:已经小心遵守这些规则了,为什么动画还会卡顿.跳帧?还能优化

Java踩坑之路

陆陆续续学Java也快一年多了,从开始的一窍不通到现在的初窥门径,我努力过,迷茫过,痛过,乐过,反思过,沉淀过.趁着新年,我希望能把这些东西记下来,就当是我一路走来的脚印. 一.初识网站应用 记得第一次接触Java,是写一个小网站,当时用servlet+tomcat做服务端,数据库是mysql.那时我对于网站应用的概念一片空白,之前接触的都是C++和MFC写桌面程序.我花了一周时间看完了<java servlet programming>这本书,然后我就开始写代码了.但是,真的当我写代码的时候

网站移动版本开发踩坑实录一

最近公司项目需要开始做wap版本开发,虽然在上一家公司也有做过类似的工作,由于当时公司产品没有严格要求适配各个移动设备,也并没有很多动作效果和图片自适应这类的效果,相对来说体系没有那么成熟,更多是在wap版本上可以用就ok了(其实更多的工作集中在功能和cssser身上,交互效果没有那么强,唯一做的好玩一点的工作是菜单滑动.图片缩放[未被上线过]),因此基本上没有在移动端踩各种坑:说了这么多上一家公司的wap版本,下面开始讲讲现在做的项目让我在wap版本上踩的各种坑开始说起.   第一坑:技术选型

前端深入之css篇丨2020年前,彻底掌握css动画【transition】

原文:前端深入之css篇丨2020年前,彻底掌握css动画[transition] 写在前面 马上就2020年了,不知道小伙伴们今年学习了css3动画了吗? 说起来css动画是一个很尬的事,一方面因为公司用css动画比较少,另一方面大部分开发者习惯了用JavaScript来做动画,所以就导致了许多程序员比较排斥来学习css动画(至少我是),但是一个不懂css动画的前端工程师不能称之为掌握css3,其实当你真正学习css动画之后,你会被它的魅力所吸引的,它可以减少代码量.提高性能. 话不多说,马上