Meteors
A meteor shower effect.
Installation
Copy and paste the following code into your project:
vue
<script setup lang='ts'>
import { cn } from '@/lib/utils'
import { ref, watch } from 'vue'
interface MeteorsProps {
number?: number
}
const props = withDefaults(defineProps<MeteorsProps>(), {
number: 20
})
const meteorStyles = ref()
watch(() => props.number, (val) => {
const styles = Array.from({ length: val }).map(() => ({
top: -5,
left: `${Math.floor(Math.random() * window.innerWidth)}px`,
animationDelay: `${Math.random() * 1 + 0.2}s`,
animationDuration: `${Math.floor(Math.random() * 8 + 2)}s`,
}))
meteorStyles.value = styles
}, {
immediate: true
})
</script>
<template>
<div v-for="(style, index) in meteorStyles" :key="index">
<span
:key="index" :class="cn(
'pointer-events-none absolute left-1/2 top-1/2 size-0.5 rotate-[215deg] animate-meteor rounded-full bg-slate-500 shadow-[0_0_0_1px_#ffffff10]',
)" :style="style"
>
<div
class="pointer-events-none absolute top-1/2 -z-10 h-px w-[50px] -translate-y-1/2 bg-gradient-to-r from-slate-500 to-transparent"
/>
</span>
</div>
</template>
Props
Prop | Type | Description | Default |
---|---|---|---|
number | number | Number of meteors | 20 |