”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 查看过渡主题动画

查看过渡主题动画

发布于2024-11-04
浏览:915

View transition theme animations

使用 CSS 和视图转换从浅色模式转换为深色模式时添加炫酷效果

复制自 Twitter 上的@jhey

[!笔记]
这假设您已经设置了暗光模式,并具有某种功能来更新您的主题

  1. 添加CSS
  /* Angled */
  [data-style='angled']::view-transition-old(root) {
    animation: none;
    z-index: -1;
  }

  [data-style='angled']::view-transition-new(root) {
    animation: unclip 1s;
    clip-path: polygon(-100vmax 100%, 100% 100%, 100% -100vmax);
  }

  @keyframes unclip {
    0% {
      clip-path: polygon(100% 100%, 100% 100%, 100% 100%);
    }
  }

  1. 确保在根元素上设置 data-style="angled" 属性 在 SPA React 中我们使用 useEffect 钩子
  useEffect(() => {
    // set the data-style attribute
    document.documentElement.dataset.style = "angled";
  }, []);

在SSR中可以直接在html标签中设置

  1. 将主题更改函数包装在 documnet.startViewTransition 中以启动视图转换
  function transitionColors() {
    if (typeof window !== "undefined") {
      document.startViewTransition(() => {
        const newTheme = theme  === "light" ? "dark" : "light";
        document.documentElement.dataset.theme = newTheme;
        updateTheme(newTheme);
      });
    }
  }

可以通过包含相应的 css 文件并添加正确的 data-style 属性来添加更多过渡样式

      

反应示例

如果你喜欢这种类型的 css 技巧,请考虑遵循 jhey

版本声明 本文转载于:https://dev.to/tigawanna/view-transition-theme-animations-8n1?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 为什么 `std::atomic` 的存储使用 XCHG 来实现 x86 上的顺序一致性?
    为什么 `std::atomic` 的存储使用 XCHG 来实现 x86 上的顺序一致性?
    为什么 std::atomic 的存储采用 XCHG 来实现顺序一致性在 x86 和 x86_64 架构的 std::atomic 上下文中,a具有顺序一致性的存储操作 (std::memory_order_seq_cst) 采用 XCHG,而不是使用内存屏障作为简单存储实现顺序释放语义的技术。顺序...
    编程 发布于2024-11-18
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-11-18
  • 为什么 C++ 不直接支持从函数返回数组?
    为什么 C++ 不直接支持从函数返回数组?
    为什么 C 不赞成数组返回函数C 景观与 Java 等语言相反,C 不支持数组返回函数不为返回数组的函数提供直接支持。虽然可以返回数组,但过程很麻烦。这引发了有关此设计决策背后的根本原因的问题。C 中的数组机制要理解这一点,我们必须深入研究 C 中数组的基础知识。 C,数组名称代表内存地址,而不是数...
    编程 发布于2024-11-18
  • 好的,以下是一些适合文章内容的标题:

* How to Fix the \"-lGL: not found\" Error in Qt
* Qt Compilation Error: \"-lGL: not found\" - What to Do
* Troubleshooting \"-lGL: not found\" Error in Qt Projects
* Resolving the
    好的,以下是一些适合文章内容的标题: * How to Fix the \"-lGL: not found\" Error in Qt * Qt Compilation Error: \"-lGL: not found\" - What to Do * Troubleshooting \"-lGL: not found\" Error in Qt Projects * Resolving the
    解决 Qt 中的“-lGL:未找到”错误尝试在 QtCreator 中编译新创建的项目时,一些用户可能会遇到错误“-lGL:未找到”。此错误通常是因为未安装所需的依赖项而发生。要解决此问题,请按照以下步骤操作: 该软件包包含 Qt 项目中支持 OpenGL 所需的开发库。在 Ubuntu 上,您可...
    编程 发布于2024-11-18
  • PHP 的“eval”函数使用起来安全吗?
    PHP 的“eval”函数使用起来安全吗?
    什么时候 eval 不是邪恶的?虽然 PHP 的 eval 函数经常被劝阻,但它在 PHP 5.3 中的实用性值得商榷。尽管出现了 LSB 和闭包,但以下是一些可以想象的用例,其中 eval 可能仍然是首选:评估安全表达式:Eval 可用于评估数值或PHP代码的其他特定子集,例如简单的数学表达式,不...
    编程 发布于2024-11-18
  • 如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    MySQL配置不正确:相对路径的问题在Django中运行python manage.py runserver时,可能会遇到以下错误:ImproperlyConfigured: Error loading MySQLdb module: dlopen(/Library/Python/2.7/site-...
    编程 发布于2024-11-18
  • 如何在 Go 中使用动态属性解组 XML?
    如何在 Go 中使用动态属性解组 XML?
    Golang:使用动态属性解组 XML简介:在 Go 中,encoding/xml 提供了处理 XML 数据的高效且通用的方法。然而,在处理具有动态属性的 XML 元素时,由于存在未知数量和类型的属性,解组变得具有挑战性。问题:如何使用以下方法解组 XML 标签:当你没有预料到会遇到的确切属性时,如...
    编程 发布于2024-11-18
  • 如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 识别今天生日的用户使用 MySQL 确定今天是否是用户的生日涉及查找生日匹配的所有行今天的日期。这可以通过一个简单的 MySQL 查询来实现,该查询将存储为 UNIX 时间戳的生日与今天的日期进行比较。以下 SQL 查询将获取今天有生日的所有用户: FROM USERS ...
    编程 发布于2024-11-18
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2024-11-18
  • C++中可以直接初始化类数据成员吗?
    C++中可以直接初始化类数据成员吗?
    类数据成员可以直接初始化吗?在 C 中,类数据成员不能使用直接初始化语法 () 进行初始化,如下例所示:#include <iostream> class test { public: void fun() { int a(3); std::cou...
    编程 发布于2024-11-18
  • 为什么 `std::cout
    为什么 `std::cout
    f 的奇事;为什么它总是在输出中打印 1?遇到一种特殊的行为,即调用不带括号 (f;) 的函数并使用 std::cout 打印其结果始终产生数字 1 可能会引发问题。最初,人们可能期望代码打印一个函数指针,但观察表明并非如此。深入研究下面的代码:#include <iostream> u...
    编程 发布于2024-11-18
  • 为什么我的 Font Awesome 图标没有显示?
    为什么我的 Font Awesome 图标没有显示?
    Font Awesome 图标显示问题:解决方法如果您遇到 Font Awesome 图标未出现在您的网站上的问题,尽管包括必要的文件,请考虑以下故障排除提示:验证 CDN 链接: 确保您使用的是正确的 CDN 链接。例如,使用:<link href="http://cdnjs...
    编程 发布于2024-11-18
  • 如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    在 PHP 中组合关联数组在 PHP 中,将两个关联数组组合成一个数组是一项常见任务。考虑以下请求:问题描述:提供的代码定义了两个关联数组,$array1 和 $array2。目标是创建一个新数组 $array3,它合并两个数组中的所有键值对。 此外,提供的数组具有唯一的 ID,而名称可能重合。要求...
    编程 发布于2024-11-18
  • 如何从 JavaScript 单击事件调用 ASP.NET 方法?
    如何从 JavaScript 单击事件调用 ASP.NET 方法?
    从 JavaScript 访问 ASP.NET 函数要从 JavaScript 的单击事件调用 ASP.NET 方法,可以使用非标准方法:受雇。这里有详细的指南:使用 IPostBackEventHandler 接口增强 Page 类:在您的 ASP.NET 代码文件中,使用以下代码继承 Page ...
    编程 发布于2024-11-18
  • 您可以在 JavaScript 中的条件语句内声明函数吗?
    您可以在 JavaScript 中的条件语句内声明函数吗?
    条件语句中的函数声明在 JavaScript 中,函数声明具有不同的行为,具体取决于流行的语言标准及其执行环境。 严格模式 (ES5)严格模式,在 ECMAScript 5 中引入(ES5),条件语句中不允许使用函数声明。这是因为函数声明创建了提升变量,这些变量的作用域为整个函数或全局作用域。将它们...
    编程 发布于2024-11-18

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3