大家好,我是林三心,用最通俗易懂的话讲最难的知识点是我的座右铭,基础是进阶的前提是我的初心。
最近看到 ElementPlus 官网上的切换主题方式非常有趣,这是一个过渡的动画效果。
图片
所以在网上查了一番,找到基本的实现方法。
首先我们起一个 html 文件,写一个按钮,以及简单的背景颜色切换,来模拟主题的切换。
图片
可以看到实现了最简单的主题切换效果。
图片
想要实现过渡效果,需要先用到一个 JavaScript 的原生方法:document.startViewTransition。
这个方法是用来做动画过渡效果的。
图片
通过调用 API,让浏览器为新旧两种不同视图分别捕获并建立了快照 (即 ::view-transition-old(root)旧快照 和 ::view-transition-new(root) 新快照),而后新旧两快照在 ::view-transition-image-pair(root) 容器中完成转场动画的过渡。动画结束后则删除其相关伪元素 (快照和容器)。
图片
我们可以应用一下这个 API。
图片
现在去切换主题颜色,发现有过渡效果了。
图片
接下来实现圆形过渡的效果,其实这个动画最终是展示::view-transition-new(root)这个伪元素,所以我们只需要让这个伪元素有原型扩散的过渡动画即可!
那圆形扩散动画咋做呢?其实很简单,只需要将伪元素的半径,从0 -> 100%即可。
图片
代码如下:
图片
并且我们需要取消掉 document.startViewTransition默认的动画效果,不然它会导致我们自定义的动画效果无效。
图片
最终得到圆形扩散的效果:
<!DOCTYPE html><html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> <style> :root { /* 默认亮主题 */ --bg-color: #fff; background-color: var(--bg-color); } :root.dark { /* 暗主题 */ --bg-color: #000; } ::view-transition-new(root), ::view-transition-old(root) { /* 关闭默认动画 */ animation: none; } </style> </head> <body> <button id="themeButton">切换主题</button> <script> const themeButton = document.getElementById("themeButton"); themeButton.addEventListener("click", (e) => { // 执行切换主题的操作 const transition = document.startViewTransition(() => { // 动画过渡切换主题色 document.documentElement.classList.toggle("dark"); }); // document.startViewTransition 的 ready 返回一个 Promise transition.ready.then(() => { // 获取鼠标的坐标 const { clientX, clientY } = e; // 计算最大半径 const radius = Math.hypot( Math.max(clientX, innerWidth - clientX), Math.max(clientY, innerHeight - clientY) ); // 圆形动画扩散开始 document.documentElement.animate( { clipPath: [ `circle(0% at ${clientX}px ${clientY}px)`, `circle(${radius}px at ${clientX}px ${clientY}px)`, ], }, // 设置时间,已经目标伪元素 { duration: 300, pseudoElement: "::view-transition-new(root)", } ); }); }); </script> </body></html>
本文链接://www.dmpip.com//www.dmpip.com/showinfo-26-100986-0.html饿了么面试官:实现一下 Element-UI 官网的主题切换动画!
声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com
上一篇: VueConf 2024 落幕,7大模块讲解 Vue 未来生态变化!
下一篇: 想看源码但是无从下口怎么办?