Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to define directives on vue3 compositionAPI?

How to define and use directives on vue3 composition api with the new syntactic sugar in SFC <script setup> format? With options API it used to be like this

import click_outside from "@/directives/click-outside.js";
export default {
  directives: {
    "click-outside": click_outside,
  }, 
  ...
}

click-outside.js

<script setup>
import {defineProps, onBeforeMount, onUnmounted, directive } from "vue";

const onBeforeMount = (el, binding) => {
  ...
};
const onUnmounted = (el) => {
 ...
};
</script>

I couldn't figure out the same counterpart code in composition API

like image 590
ShegaMike Avatar asked Oct 23 '25 19:10

ShegaMike


2 Answers

@Estus Flask's answer is enough but just to clarify, you just import directives like you do with components with PascalCase or camelCase and you can directly use it in your templates.

<script setup>
import vClickOutside from "@/directives/click-outside.js";
const outside = () =>{ ... }
...
</script>
<template>
...
<div v-click-outside="outside">
...
...
</template>

like image 167
ShegaMike Avatar answered Oct 26 '25 08:10

ShegaMike


Feature parity with regular script SFC is achieved in 3 different ways.

props argument from setup and props, emits, expose fields from component options are provided by using define... helpers.

context (only slots and attrs properties) argument from setup is provided by using use... helpers.

components and directives are indirectly provided by using imports of the same name.

The rest of features (e.g. name property) are still provided by script element that can coexist with script setup.

like image 24
Estus Flask Avatar answered Oct 26 '25 09:10

Estus Flask



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!