VueUse、View Transitions API实现暗黑模式主题动画切换效果

编程入门 行业动态 更新时间:2024-10-21 03:42:19

VueUse、View Transitions API实现暗黑模式主题动画切换<a href=https://www.elefans.com/category/jswz/34/1770448.html style=效果"/>

VueUse、View Transitions API实现暗黑模式主题动画切换效果

VueUse、View Transitions API实现暗黑模式主题动画切换效果

  • 前言
    • View Transitions API
      • 兼容版本
    • VueUse
  • 正题
    • 效果
    • 安装
    • 代码

作者GitHub: 有兴趣可关注!!

前言

View Transitions API

View Transitions API 是原生JavaScript提供一种能让Dom更加丝滑的API

示例👇

兼容版本

VueUse

Vue的工具函数合集 /

正题

效果

安装

npm install @vueuse/core
or
pnpm install @vueuse/core
or
yarn add @vueuse/core

代码

以下代码放入自己项目对应文件中即可

/* 进入dark模式和退出dark模式时,两个图像的位置顺序正好相反 */
/* 根据自己选择器修改 */
[data-bs-theme='dark']::view-transition-old(root) {z-index: 1;
}
[data-bs-theme='dark']::view-transition-new(root) {z-index: 999;
}::view-transition-old(root) {z-index: 999;
}
::view-transition-new(root) {z-index: 1;
}
import { useDark, useToggle } from '@vueuse/core'const isDark = useDark({selector: 'html',attribute: 'data-bs-theme',valueDark: 'dark',valueLight: 'light'
})const toggleDark = useToggle(isDark)
const toggleTheme = (event) => {const x = event.clientXconst y = event.clientYconst endRadius = Math.hypot(Math.max(x, innerWidth - x), Math.max(y, innerHeight - y))// 兼容性处理if (!document.startViewTransition) {toggleDark()return}const transition = document.startViewTransition(() => {toggleDark()})transition.ready.then(() => {const clipPath = [`circle(0px at ${x}px ${y}px)`, `circle(${endRadius}px at ${x}px ${y}px)`]// 关于【documentElement.animate】.documentElement.animate({clipPath: !isDark.value ? [...clipPath].reverse() : clipPath},{duration: 400,easing: 'ease-in',pseudoElement: !isDark.value ? '::view-transition-old(root)' : '::view-transition-new(root)'})})
}






到这里就结束了,后续还会更新 前端 系列相关,还请持续关注!
感谢阅读,若有错误可以在下方评论区留言哦!!!




推荐文章👇

太丝滑了!了解一下原生的视图转换动画 View Transitions

更多推荐

VueUse、View Transitions API实现暗黑模式主题动画切换效果

本文发布于:2023-11-15 23:00:50,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1608457.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:效果   模式   动画   主题   View

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!