当前位置:首页 > 科技  > 软件

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

来源: 责编: 时间:2024-07-15 17:15:39 723观看
导读前言大家好,我是林三心,用最通俗易懂的话讲最难的知识点是我的座右铭,基础是进阶的前提是我的初心。最近看到 ElementPlus 官网上的切换主题方式非常有趣,这是一个过渡的动画效果。图片所以在网上查了一番,找到基本的实现

前言

大家好,我是林三心,用最通俗易懂的话讲最难的知识点是我的座右铭,基础是进阶的前提是我的初心。ysd28资讯网——每日最新资讯28at.com

最近看到 ElementPlus 官网上的切换主题方式非常有趣,这是一个过渡的动画效果。ysd28资讯网——每日最新资讯28at.com

图片图片ysd28资讯网——每日最新资讯28at.com

ysd28资讯网——每日最新资讯28at.com

所以在网上查了一番,找到基本的实现方法。ysd28资讯网——每日最新资讯28at.com

实现

基本效果

首先我们起一个 html 文件,写一个按钮,以及简单的背景颜色切换,来模拟主题的切换。ysd28资讯网——每日最新资讯28at.com

图片图片ysd28资讯网——每日最新资讯28at.com

ysd28资讯网——每日最新资讯28at.com

可以看到实现了最简单的主题切换效果。ysd28资讯网——每日最新资讯28at.com

图片图片ysd28资讯网——每日最新资讯28at.com

ysd28资讯网——每日最新资讯28at.com

document.startViewTransition

想要实现过渡效果,需要先用到一个 JavaScript 的原生方法:document.startViewTransition。ysd28资讯网——每日最新资讯28at.com

这个方法是用来做动画过渡效果的。ysd28资讯网——每日最新资讯28at.com

图片图片ysd28资讯网——每日最新资讯28at.com

ysd28资讯网——每日最新资讯28at.com

通过调用 API,让浏览器为新旧两种不同视图分别捕获并建立了快照 (即 ::view-transition-old(root)旧快照 和 ::view-transition-new(root) 新快照),而后新旧两快照在 ::view-transition-image-pair(root) 容器中完成转场动画的过渡。动画结束后则删除其相关伪元素 (快照和容器)。ysd28资讯网——每日最新资讯28at.com

图片图片ysd28资讯网——每日最新资讯28at.com

ysd28资讯网——每日最新资讯28at.com

过渡动画效果

我们可以应用一下这个 API。ysd28资讯网——每日最新资讯28at.com

图片图片ysd28资讯网——每日最新资讯28at.com

ysd28资讯网——每日最新资讯28at.com

现在去切换主题颜色,发现有过渡效果了。ysd28资讯网——每日最新资讯28at.com

图片图片ysd28资讯网——每日最新资讯28at.com

ysd28资讯网——每日最新资讯28at.com

圆形扩散过渡动画

接下来实现圆形过渡的效果,其实这个动画最终是展示::view-transition-new(root)这个伪元素,所以我们只需要让这个伪元素有原型扩散的过渡动画即可!ysd28资讯网——每日最新资讯28at.com

那圆形扩散动画咋做呢?其实很简单,只需要将伪元素的半径,从0 -> 100%即可。ysd28资讯网——每日最新资讯28at.com

图片图片ysd28资讯网——每日最新资讯28at.com

ysd28资讯网——每日最新资讯28at.com

代码如下:ysd28资讯网——每日最新资讯28at.com

图片图片ysd28资讯网——每日最新资讯28at.com

ysd28资讯网——每日最新资讯28at.com

并且我们需要取消掉 document.startViewTransition默认的动画效果,不然它会导致我们自定义的动画效果无效。ysd28资讯网——每日最新资讯28at.com

图片图片ysd28资讯网——每日最新资讯28at.com

ysd28资讯网——每日最新资讯28at.com

最终得到圆形扩散的效果:ysd28资讯网——每日最新资讯28at.com

图片ysd28资讯网——每日最新资讯28at.com

ysd28资讯网——每日最新资讯28at.com

完整代码

<!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>

本文链接:http://www.28at.com/showinfo-26-100986-0.html饿了么面试官:实现一下 Element-UI 官网的主题切换动画!

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: VueConf 2024 落幕,7大模块讲解 Vue 未来生态变化!

下一篇: 想看源码但是无从下口怎么办?

标签:
  • 热门焦点
  • Find N3入网:最高支持16+1TB

    OPPO将于近期登场的Find N3折叠屏目前已经正式入网,型号为PHN110。本次Find N3在外观方面相比前两代有很大的变化,不再是小号的横向折叠屏,而是跟别的厂商一样采用了较为常见的
  • 7月安卓手机性价比榜:努比亚+红魔两款新机入榜

    7月登场的新机有努比亚Z50S Pro和红魔8S Pro,除了三星之外目前唯二的两款搭载超频版骁龙8Gen2处理器的产品,而且努比亚和红魔也一贯有着不错的性价比,所以在本次的性价比榜单
  • Raft算法:保障分布式系统共识的稳健之道

    1. 什么是Raft算法?Raft 是英文”Reliable、Replicated、Redundant、And Fault-Tolerant”(“可靠、可复制、可冗余、可容错”)的首字母缩写。Raft算法是一种用于在分布式系统
  • 摸鱼心法第一章——和配置文件说拜拜

    为了能摸鱼我们团队做了容器化,但是带来的问题是服务配置文件很麻烦,然后大家在群里进行了“亲切友好”的沟通图片图片图片图片对比就对比,简单对比下独立配置中心和k8s作为配
  • 让我们一起聊聊文件的操作

    文件【1】文件是什么?文件是保存数据的地方,是数据源的一种,比如大家经常使用的word文档、txt文件、excel文件、jpg文件...都是文件。文件最主要的作用就是保存数据,它既可以保
  • 2023年,我眼中的字节跳动

    此时此刻(2023年7月),字节跳动从未上市,也从未公布过任何官方的上市计划;但是这并不妨碍它成为中国最受关注的互联网公司之一。从2016-17年的抖音强势崛起,到2018年的&ldquo;头腾
  • 认真聊聊东方甄选:如何告别低垂的果实

    来源:山核桃作者:财经无忌爆火一年后,俞敏洪和他的东方甄选依旧是颇受外界关心的&ldquo;网红&rdquo;。7月5日至9日,为期5天的东方甄选&ldquo;甘肃行&rdquo;首次在自有App内直播,
  • 三星Galaxy Z Fold5今日亮相:厚度缩减但仍略显厚重

    据官方此前宣布,三星将于7月26日也就是今天在韩国首尔举办Unpacked活动,届时将带来带来包括Galaxy Buds 3、Galaxy Watch 6、Galaxy Tab S9、Galaxy
  • 三星Galaxy Z Fold5官方渲染图曝光:13.4mm折叠厚度依旧感人

    据官方此前宣布,三星将于7月26日在韩国首尔举办Unpacked活动,届时将带来带来包括Galaxy Buds 3、Galaxy Watch 6、Galaxy Tab S9、Galaxy Z Flip 5、
Top