Vue 中在setup 下使用自定义指令
1. 局部的自定义指令
html 中 v-img-rotote 为自定义指令
<div class="card-item">
<div class="img">
<img v-img-rotote src="~@/assets/images/funny.png" />
</div>
<div class="text-title lineEllipsisOne">小火车况且况且</div>
</div>
在setup 下面直接引用就行
<script lang="ts" setup>
const vImgRotote = {
beforeMount(el: HTMLElement) {
el.onmouseover = () => {
el.style.transform = 'rotate(-360deg)'
el.style.transition = 'all 0.5s'
}
el.onmouseleave = () => {
el.style.transform = 'rotate(0)'
}
}
}
</script>
- 方式二是在固定文件夹下编写好了指令代码, 然后直接引用即可, 前提是代码不能出错的哟👋
<script lang="ts" setup>
import vImgRotote from '@/directives/imgRotote'
</script>
小提示???: 如果这个时候安装了vscode中的Volar 插件, 定义的代码就会高亮显示
2. 全局注册自定义指令
全局和局部的自定义只是引用方式不同, 这里只是代表个人的写法, 小伙伴要有更好的可以直接忽视老夫的
- 在
src/directives 中添加一个index.ts 文件, 用来注册所有的需要全局导入的自定义指令 index.ts 的文件内容, permission 是用来提示可以直接使用链式编程的写法注册其他的全局自定义指令
import type { App } from 'vue'
import permission from './permission'
import imgRotote from './imgRotote'
export default (app: App) => {
app.directive('img-rotote', imgRotote).directive('permission', permission)
}
- 然后将
src/directives 中的index.ts 导入到main.ts 中, 用来全局注册, 最后将app 传入, 用来注册全局的自定义指令
import { createApp } from 'vue'
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
import App from './App.vue'
import router from './router'
import { store, key } from './store'
import globalDirectives from '@/directives'
const app = createApp(App)
app.use(store, key).use(router).use(ElementPlus).mount('#app')
globalDirectives(app)
- 直接在代码中引用即可
<div class="card-item">
<div class="img">
<img v-img-rotote src="~@/assets/images/funny.png" />
</div>
<div class="text-title lineEllipsisOne">小火车况且况且</div>
</div>
3. 简单的效果图
4. 千万要注意
注册自定义指令时, 定义的name 指令名称在使用的时候,不要写错了, 这里注册的全局和局部的自定义指令名称都是img-rotote , 所以在html 中使用时需要v-img-rotote , 如下
<img v-img-rotote src="~@/assets/images/funny.png" />
|