【bug记录6】css 写animation时,Safari浏览器最后一帧部分样式闪回

本文主要是介绍【bug记录6】css 写animation时,Safari浏览器最后一帧部分样式闪回,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、问题场景

1、目标动画的实现:

想实现一个元素A从位置1平移到位置2,并且在移动过程中逐渐缩小、透明度变小

2、原代码实现:
.a{//分别设置了:动画keyframes名称、单次持续时间、//timing function、delay时间、iter count//以及animation-fill-mode(代表的是动画开始前后保持在哪个样式)animation: move 0.3s linear 1s 3 both;
}@keyframes move {0% {transform: scale(1);opacity: 1;top: 16vh;left: 40vw;}100% {transform: scale(0.5);opacity: 0.5;top: 6vh;left: 10vw;}
}
3、产生效果:
  • 谷歌浏览器按照预期进行
  • Safari浏览器,在动画的最后一帧时,回到初始的scale和opacity设置,但并没有移动到相应的偏移位置

二、问题原因

根据在动画的最后一帧时,元素回到初始的scale和opacity设置,但并没有移动到相应的偏移位置这一信息,可以知道并非fill-mode没有生效,而是在渲染初始样式时,偏移位置没有和scale、opacity同步生效

根据三者属性的差别,transform、opacity是用gpu渲染的属性,gpu的性能高、渲染生效速度更快。而left、top的设置需要对DOM节点进行操作,而非图层计算,因此可能在不同的浏览器性能下造成复杂动画渲染不同步的问题。

三、问题解决

使用translate来进行动画位移!

代码如下:

@keyframes move {0% {transform: translate(40vw,16vh) scale(1);opacity: 1;}100% {transform: translate(10vw,6vh)  scale(0.5);opacity: 0.5;}
}

 transform实现多维度变形时,用空格隔开

transform的最佳排列顺序是translate、scale、rotate,避免计算偏离预期(当然也要根据变形需要再针对性看)

这篇关于【bug记录6】css 写animation时,Safari浏览器最后一帧部分样式闪回的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1114001

相关文章

HTML5中的Microdata与历史记录管理详解

《HTML5中的Microdata与历史记录管理详解》Microdata作为HTML5新增的一个特性,它允许开发者在HTML文档中添加更多的语义信息,以便于搜索引擎和浏览器更好地理解页面内容,本文将探... 目录html5中的Mijscrodata与历史记录管理背景简介html5中的Microdata使用M

html5的响应式布局的方法示例详解

《html5的响应式布局的方法示例详解》:本文主要介绍了HTML5中使用媒体查询和Flexbox进行响应式布局的方法,简要介绍了CSSGrid布局的基础知识和如何实现自动换行的网格布局,详细内容请阅读本文,希望能对你有所帮助... 一 使用媒体查询响应式布局        使用的参数@media这是常用的

HTML5表格语法格式详解

《HTML5表格语法格式详解》在HTML语法中,表格主要通过table、tr和td3个标签构成,本文通过实例代码讲解HTML5表格语法格式,感兴趣的朋友一起看看吧... 目录一、表格1.表格语法格式2.表格属性 3.例子二、不规则表格1.跨行2.跨列3.例子一、表格在html语法中,表格主要通过< tab

Java使用SLF4J记录不同级别日志的示例详解

《Java使用SLF4J记录不同级别日志的示例详解》SLF4J是一个简单的日志门面,它允许在运行时选择不同的日志实现,这篇文章主要为大家详细介绍了如何使用SLF4J记录不同级别日志,感兴趣的可以了解下... 目录一、SLF4J简介二、添加依赖三、配置Logback四、记录不同级别的日志五、总结一、SLF4J

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

在Spring Boot中浅尝内存泄漏的实战记录

《在SpringBoot中浅尝内存泄漏的实战记录》本文给大家分享在SpringBoot中浅尝内存泄漏的实战记录,结合实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录使用静态集合持有对象引用,阻止GC回收关键点:可执行代码:验证:1,运行程序(启动时添加JVM参数限制堆大小):2,访问 htt

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

前端CSS Grid 布局示例详解

《前端CSSGrid布局示例详解》CSSGrid是一种二维布局系统,可以同时控制行和列,相比Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,:本文主要介绍前端CSSGri... 目录css Grid 布局详解(通俗易懂版)一、概述二、基础概念三、创建 Grid 容器四、定义网格行和列五、设置行

前端下载文件时如何后端返回的文件流一些常见方法

《前端下载文件时如何后端返回的文件流一些常见方法》:本文主要介绍前端下载文件时如何后端返回的文件流一些常见方法,包括使用Blob和URL.createObjectURL创建下载链接,以及处理带有C... 目录1. 使用 Blob 和 URL.createObjectURL 创建下载链接例子:使用 Blob