专栏名称: 前端之神
一位前端小菜鸡,写过300多篇原创文章,全网有5w+个前端朋友,梦想是成为”前端之神“~
目录
相关文章推荐
BioArt  ·  ​Science | ... ·  昨天  
移民(微博搜索)  ·  移民(微博搜索)-20250206-3 ·  3 天前  
北美留学生观察  ·  福布斯中国推出留学行业系列评选,遴选中国优秀 ... ·  3 天前  
51好读  ›  专栏  ›  前端之神

饿了么面试官:实现一下 Element-UI 官网的主题切换动画!

前端之神  · 公众号  ·  · 2024-11-27 08:40

正文

饿了么面试官:实现一下 Element-UI 官网的主题切换动画!

前言

大家好,我是林三心,用最通俗易懂的话讲最难的知识点是我的座右铭,基础是进阶的前提是我的初心~

最近看到 ElementPlus 官网上的切换主题方式非常有趣,这是一个过渡的动画效果


所以在网上查了一番,找到基本的实现方法

实现

基本效果

首先我们起一个 html 文件,写一个按钮,以及简单的背景颜色切换,来模拟主题的切换


可以看到实现了最简单的主题切换效果


document.startViewTransition

想要实现过渡效果,需要先用到一个 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 默认的动画效果,不然它会导致我们自定义的动画效果无效~


最终得到圆形扩散的效果


完整代码

html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Documenttitle>
    <style>
      :root {
        /* 默认亮主题 */
        --bg-color#fff;
        background-colorvar(--bg-color);
      }
      :root.dark {
        /* 暗主题 */
        --bg-color#000;
      }
      ::view-transition-new(root),
      ::view-transition-old(root) {
        /* 关闭默认动画 */
        animation: none;
      }
    
style>
  head>
  <body>
    <button






请到「今天看啥」查看全文