Nie możesz wybrać więcej, niż 25 tematów Tematy muszą się zaczynać od litery lub cyfry, mogą zawierać myślniki ('-') i mogą mieć do 35 znaków.
 
 
 
 
 

20 wiersze
570 B

  1. export function useMouse() {
  2. // state encapsulated and managed by the composable
  3. const x = ref(0)
  4. const y = ref(0)
  5. // a composable can update its managed state over time.
  6. function update(event) {
  7. x.value = event.pageX
  8. y.value = event.pageY
  9. }
  10. // a composable can also hook into its owner component's
  11. // lifecycle to setup and teardown side effects.
  12. onMounted(() => window.addEventListener('mousemove', update))
  13. onUnmounted(() => window.removeEventListener('mousemove', update))
  14. // expose managed state as return value
  15. return { x, y }
  16. }