A Vue 2 plugin that provides a custom directive allowing the usage of any tooltip component as a directive.
Currently built for Vuetify and depends on usage of their components' activator
functionality, however I'm sure this could be adapted to handle others.
-
Install the npm dependency:
npm install --save vue-tooltip-directive
-
Include the plugin into your Vue app by adding a
Vue.use(..)
in the root file of your Vue project (usuallymain.js/main.ts
):
import Vue from 'vue'
import VueTooltipDirective from 'vue-tooltip-directive'
Vue.use(VueTooltipDirective)
- You should now be able to use the directive in your project on any display component:
<span v-tooltip="'A cool and helpful tooltip!'">
Hover me!
</span>
vue-tooltip-directive
provides a default Tooltip component for you, but if you want to customize it you can simply create your own and pass it to the plugin as thecomponent
key in the config object:
import MyCustomTooltip from '@/components/MyCustomTooltip.vue'
Vue.use(VueTooltipDirective, {
component: MyCustomTooltip
})
The directive binding can be used in a few different ways:
v-tooltip="'Basic explanatory tooltip'"
v-tooltip:left="'Left aligned tooltip'"
v-tooltip:[variable]="'Dynamically positioned tooltip'"
v-tooltip="{ content: 'Config object tooltip', position: 'right', anyExtraProps: 'here!' }"
If no position is provided either via the directive argument or in the config object, it will default to top
.
Any extra values provided in the config object will also be passed to your custom component as props.
Field | Values |
---|---|
content | string |
position | 'top' | 'right' | 'bottom' | 'left' |
All contributions are welcome via PR.
This is a hobby project and as such may feature bugs or performance issues, and you are welcome to help me diagnose or fix these.