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

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

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

前言

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

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

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

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

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

实现

基本效果

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

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

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

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

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

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

document.startViewTransition

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

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

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

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

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

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

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

过渡动画效果

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

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

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

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

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

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

圆形扩散过渡动画

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

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

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

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

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

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

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

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

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

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

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

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

vSq28资讯网——每日最新资讯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 未来生态变化!

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

标签:
  • 热门焦点
  • 一加Ace2 Pro官宣:普及16G内存 引领24G

    一加官方今天继续为本月发布的新机一加Ace2 Pro带来预热,公布了内存方面的信息。“淘汰 8GB ,12GB 起步,16GB 普及,24GB 引领,还有呢?#一加Ace2Pro#,2023 年 8 月,敬请期待。”同时
  • 6月安卓手机性能榜:vivo/iQOO霸占旗舰排行榜前三

    2023年上半年已经正式过去了,我们也迎来了安兔兔V10版本,在新的骁龙8Gen3和天玑9300发布之前,性能榜的榜单大体会以骁龙8Gen2和天玑9200+为主,至于那颗3.36GHz的骁龙8Gen2领先
  • 如何使用JavaScript创建一只图像放大镜?

    译者 | 布加迪审校 | 重楼如果您曾经浏览过购物网站,可能遇到过图像放大功能。它可以让您放大图像的特定区域,以便浏览。结合这个小小的重要功能可以大大改善您网站的用户体验
  • 每天一道面试题-CPU伪共享

    前言:了不起:又到了每天一到面试题的时候了!学弟,最近学习的怎么样啊 了不起学弟:最近学习的还不错,每天都在学习,每天都在进步! 了不起:那你最近学习的什么呢? 了不起学弟:最近在学习C
  • 雅柏威士忌多款单品价格大跌,泥煤顶流也不香了?

    来源 | 烈酒商业观察编 | 肖海林今年以来,威士忌市场开始出现了降温迹象,越来越多不断暴涨的网红威士忌也开始悄然回归市场理性。近日,LVMH集团旗下苏格兰威士忌品牌雅柏(Ardbeg
  • 一条抖音4亿人围观 ! 这家MCN比无忧传媒还野

    作者:Hiu 来源:互联网品牌官01 擦边少女空降热搜,幕后推手曝光被网友誉为&ldquo;纯欲天花板&rdquo;的女网红井川里予,近期因为一组哥特风照片登上热搜,引发了一场互联网世界关于
  • 阿里瓴羊One推出背后,零售企业迎数字化新解

    作者:刘旷近年来随着数字经济的高速发展,各式各样的SaaS应用服务更是层出不穷,但本质上SaaS大多局限于单一业务流层面,对用户核心关切的增长问题等则没有提供更好的解法。在Saa
  • 造车两年股价跌六成,小米的估值逻辑变了吗?

    如果从小米官宣造车后的首个交易日起持有小米集团的股票,那么截至2023年上半年最后一个交易日,投资者将浮亏59.16%,同区间的恒生科技指数跌幅为52.78%
  • 华为Mate 60保护壳曝光:硕大后置相机模组 凸起程度有惊喜

    这段时间以来,关于华为新旗舰的爆料日渐密集。据此前多方爆料,今年华为将开始恢复一年双旗舰战略,除上半年推出的P60系列外,往年下半年的Mate系列也将
Top