svg+css实现文字鼠标悬停星星闪耀动画效果代码
代码语言:html
所属分类:悬停
代码描述:svg+css实现文字鼠标悬停星星闪耀动画效果代码
代码标签: svg css 文字 鼠标 悬停 星星 闪耀 动画
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html> <html lang="en" > <head> <meta charset="UTF-8"> <style> @import url('//repo.bfw.wiki/bfwrepo/css/normalize.min.css') layer(normalize); @layer normalize, base, demo; @layer demo { :root { --color: light-dark(hsl(45.2deg 97.42% 64.31%), hsl(45.2deg 97.42% 54.31%)); --shadow: light-dark(hsl(35deg 100% 57.06%), hsl(35deg 100% 47.06%)); --glare: light-dark(white, hsl(0 0% 100% / 0.75)); --transition: 0.2s; } .dazzle { --font-level: 5; --font-size: 1em; --padding: 0.12em; padding: var(--padding) calc(var(--padding) * 2); border-radius: 0.25em; text-decoration: none; color: transparent; position: relative; transition: background 0.2s 0.1s; font-weight: 600; } .dazzle:is(:hover, :focus-visible) { background: color-mix(in hsl, canvasText, #0000 86%); } .dazzle span { display: inline-block; transition: all 0.2s; text-decoration: none; text-shadow: calc(var(--hover) * (var(--font-size) * -0)) calc(var(--hover) * (var(--font-size) * 0)) var(--shadow), calc(var(--hover) * (var(--font-size) * -0.02)) calc(var(--hover) * (var(--font-size) * 0.02)) var(--shadow), calc(var(--hover) * (var(--font-size) * -0.04)) calc(var(--hover) * (var(--font-size) * 0.04)) var(--shadow), calc(var(--hover) * (var(--font-size) * -0.06)) calc(var(--hover) * (var(--font-size) * 0.06)) var(--shadow), calc(var(--hover) * (var(--font-size) * -0.08)) calc(var(--hover) * (var(--font-size) * 0.08)) var(--shadow), calc(var(--hover) * (var(--font-size) * -0.1)) calc(var(--hover) * (var(--font-size) * 0.1)) var(--shadow); transform: translate( calc(var(--hover) * (var(--font-size) * 0.1)), calc(var(--hover) * (var(--font-size) * -0.1)) ); } .dazzle span:last-of-type { position: absolute; inset: var(--padding) calc(var(--padding) * 2); background: linear-gradient( 108deg, transparent 0 55%, var(--glare) 55% 60%, transparent 60% 70%, var(--glare) 70% 85%, transparent 85% ) calc(var(--pos) * -200%) 0% / 200% 100%, var(--color); -webkit-background-clip: text; color: transparent; z-index: 2; text-shadow: none; transform: translate( calc(var(--hover) * (var(--font-size) * 0.1)), calc(var(--hover) * (var(--font-size) * -0.1)) ); } .dazzle span:last-of-type { transition: transform 0.2s, background-position 0s; } .dazzle:is(:hover, :focus-visible) span:last-of-type { transition: transform 0.2s, background-position calc(var(--hover) * 1.5s) calc(var(--hover) * 0.25s); } .dazzle { --hover: 0.4; --pos: 0; } .dazzle:is(:hover, :focus-visible) { --hover: 1; --pos: 1; } .dazzle:active { --hover: 0; } .dazzle:active span:last-of-type { --hover: 0; --pos: 1; } .dazzle svg { position: absolute; z-index: 3; width: calc(var(--font-size) * 0.5); aspect-ratio: 1; } .dazzle svg path { fill: var(--glare); } /* Animation for sparkles */ .dazzle:focus-visible { outline: none; } .dazzle:is(:hover, :focus-visible) svg { -webkit-animation: sparkle 0.75s calc(0.1s + ((var(--delay-step) * var(--d)) * 1s)) both; animation: sparkle 0.75s calc(0.1s + ((var(--delay-step) * var(--d)) * 1s)) both; } @-webkit-keyframes sparkle { 50% { transform: translate(-50%, -50%) scale(var(--s, 1)); } } @keyframes sparkle { 50% { transform: translate(-50%, -50%) scale(var(--s, 1)); } } .dazzle svg { --delay-step: 0.15; top: calc(var(--y, 50) * 1%); left: calc(var(--x, 0) * 1%); transform: translate(-50%, -50%) scale(0); stroke-width: 1; stroke: light-dark(black, #0000); } .dazzle svg:nth-of-type(1) { --x: 0; --y: 20; --s: 1.1; --d: 1; } .dazzle svg:nth-of-type(2) { --x: 15; --y: 80; --s: 1.25; --d: 2; } .dazzle svg:nth-of-type(3) { --x: 45; --y: 40; --s: 1.1; --d: 3; } .dazzle svg:nth-of-type(4) { --x: 75; --y: 60; --s: 0.9; --d: 2; } .dazzle svg:nth-of-type(5) { --x: 100; --y: 30; --s: 0.8; --d: 4; } } @layer base { :root { --font-size-min: 16; --font-size-max: 20; --font-ratio-min: 1.2; --font-ratio-max: 1.33; --font-width-min: 375; --font-width-max: 1500; } html { color-scheme: light dark; } [data-theme='light'] { color-scheme: light only; } [data-theme='dark'] { color-scheme: dark only; } :where(.fluid) { --fluid-min: calc( var(--font-size-min) * pow(var(--font-ratio-min), var(--font-level, 0)) ); --fluid-max: calc( var(--font-size-max) * pow(var(--font-ratio-max), var(--font-level, 0)) ); --fluid-preferred: calc( (var(--fluid-max) - var(--fluid-min)) / (var(--font-width-max) - var(--font-width-min)) ); --fluid-type: clamp( (var(--fluid-min) / 16) * 1rem, ((var(--fluid-min) / 16) * 1rem) - (((var(--fluid-preferred) * var(--font-width-min)) / 16) * 1rem) + (var(--fluid-preferred) * var(--variable-unit, 100vi)), (var(--fluid-max) / 16) * 1rem ); font-size: var(--fluid-type); } *, *:after, *:before { box-sizing: border-box; } body { display: grid; place-items: center; min-height: 100vh; font-family: 'SF Pro Text', 'SF Pro Icons', 'AOS Icons', 'Helvetica Neue', Helvetica, Arial, sans-serif, system-ui; } body::before { --size: 45px; --line: color-mix(in lch, canvasText, transparent 70%); content: ''; height: 100vh; width: 100vw; position: fixed; background: linear-gradient( 90deg, var(--line) 1px, transparent 1px var(--size) ) 50% 50% / var(--size) var(--size), l.........完整代码请登录后点击上方下载按钮下载查看
网友评论0