Skip to content
/ motion Public
  • Sponsor
  • Notifications You must be signed in to change notification settings
  • Fork 94

๐Ÿคน Vue Composables putting your components in motion

License

Notifications You must be signed in to change notification settings

vueuse/motion

Folders and files

NameName
Last commit message
Last commit date

Latest commit

bd6fa4d ยท Oct 11, 2024
Sep 6, 2024
Sep 4, 2024
Sep 4, 2024
Sep 6, 2024
Oct 11, 2024
Sep 4, 2024
Mar 24, 2022
Mar 24, 2022
May 25, 2023
Jan 19, 2021
Sep 6, 2024
Feb 4, 2021
Sep 6, 2024
Sep 4, 2024
May 25, 2023
May 30, 2024
May 30, 2024
Sep 6, 2024
Sep 6, 2024
May 30, 2024
May 30, 2024
Oct 11, 2024

Repository files navigation

๐Ÿคน @vueuse/motion

npm npm npm Netlify Status

Vue Composables putting your components in motion

  • ๐ŸŽ Smooth animations based on Popmotion
  • ๐ŸŽฎ Declarative API inspired by Framer Motion
  • ๐Ÿš€ Plug & play with 20+ presets
  • ๐ŸŒ SSR Ready
  • ๐Ÿšš First-class support for Nuxt 3
  • โœจ Written in TypeScript
  • ๐Ÿ‹๏ธโ€โ™€๏ธ Lightweight with <20kb bundle size

๐ŸŒ Documentation

๐Ÿ‘€ Demos

Quick Start

Let's get started by installing the package and adding the plugin.

From your terminal:

npm install @vueuse/motion

In your Vue app entry file:

import { createApp } from 'vue'
import { MotionPlugin } from '@vueuse/motion'
import App from './App.vue'

const app = createApp(App)

app.use(MotionPlugin)

app.mount('#app')

You can now animate any of your component, HTML or SVG elements using v-motion.

<template>
  <div
    v-motion
    :initial="{
      opacity: 0,
      y: 100,
    }"
    :enter="{
      opacity: 1,
      y: 0,
    }"
  />
</template>

To see more about how to use directives, check out Directive Usage.

To see more about what properties you can animate, check out Motion Properties.

To see more about how to create your own animation styles, check out Transition Properties.

To see more about what are variants and how you can use them, check out Variants.

To see more about how to control your declared variants, check out Motion Instance.

Nightly release channel

You can try out the latest changes before a stable release by installing the nightly release channel.

npm install @vueuse/motion@npm:vueuse-motion-nightly

Credits

This package is heavily inspired by Framer Motion by @mattgperry.

If you are interested in using WAAPI, check out Motion.dev!

I would also like to thank antfu, patak-dev and kazupon for their kind help!

If you like this package, consider following me on GitHub and on Twitter.

๐Ÿ‘‹

Sponsor this project

Sponsor

Languages