vue3+TS 實現(xiàn)自定義指令長按觸發(fā)綁定的函數(shù)
而然間看到一個在vue2中寫的長按觸發(fā)事件的自定義指定,想著能不能把他copy到我的vue3項目中呢。
編寫自定義指令時遇到的幾個難點
1.自定義指令的類型
在ts中寫任何東西都要考慮到類型的問題,自定義指令的類型問題依然存在
2.在ts中使用setTimeout() 函數(shù)
setTimeout()函數(shù)的默認(rèn)返回值是一個隨機的number ,這個number 代表了這個計時器的唯一id,但是并不能直接將其類型定義為number 否則會出現(xiàn)報錯。
3.自定義指令的傳參問題
我這里的傳參方法只做參考,寫的很不規(guī)范。具體的好多傳參的方法請自行搜索
代碼
這個是我自己編寫的長按觸發(fā)綁定的函數(shù)
directives/longPress.ts
import { ObjectDirective } from 'vue'
const LongPress: ObjectDirective = {
// 組件mounted時執(zhí)行指令
mounted(el, binding, vNode) {
// 確保提供的表達(dá)式是函數(shù)
if (typeof binding.value !== 'function') {
// // 將警告?zhèn)鬟f給控制臺
let warn = `[longpress:] provided expression '${binding.value}' is not afunction, but has to be `
console.log(warn)
} else {
console.table({ el, binding, vNode })
let timer: ReturnType<typeof setTimeout> | null = null //定義空 定時器
const start = (e: MouseEvent | TouchEvent) => {
console.log(e)
//下列事件不執(zhí)行1.不是鼠標(biāo)左鍵2.單擊事件 (3.沒有傳入長按時間 ?? 有默認(rèn))
if ((<MouseEvent>e).button !== 0 && e.type === 'click') {
return
}
if (timer == null) {
timer = setTimeout(() => {
handler()
}, Number(binding.arg) * 1000 ?? 0.5 * 10000) //默認(rèn)長按0.5秒執(zhí)行綁定的函數(shù)
}
}
const cancel = () => {
if (timer !== null) {
clearTimeout(timer)
console.log(timer);//定時器默認(rèn)返回一個隨機的number 這個number的值是這個定時器的id
timer = null
}
}
const handler = () => {
binding.value()
}
// 添加事件監(jiān)聽器
el.addEventListener('mousedown', start)
el.addEventListener('touchstart', start)
// 取消計時器
el.addEventListener('click', cancel)
el.addEventListener('mouseout', cancel)
el.addEventListener('touchend', cancel)
el.addEventListener('touchcancel', cancel)
}
},
}
export default LongPress在main.ts中引入 作為全局自定義指令
import { createApp } from 'vue'
import App from './App.vue'
import LongPress from './directives/longpress'
const app = createApp(App)
app.directive('longPress',LongPress)
app.mount('#app')在組件中使用
這里的v-longPress 便是自定義指令,其中此處的參數(shù)傳遞方法僅供參考
<template>
<div>
<button v-longPress = 'longFunc,1' >longPress</button>
</div>
</template>
<script setup lang="ts">
const longFunc = () => {
console.log('click long btn');
alert('click long btn')
}
</script>
<style scoped>
</style>到此這篇關(guān)于vue3+TS 自定義指令:長按觸發(fā)綁定的函數(shù)的文章就介紹到這了,更多相關(guān)vue3 ts自定義指令內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用Vue純前端實現(xiàn)發(fā)送短信驗證碼并實現(xiàn)倒計時
在實際的應(yīng)用開發(fā)中,涉及用戶登錄驗證、密碼重置等場景時,通常需要前端實現(xiàn)發(fā)送短信驗證碼的功能,以提升用戶體驗和安全性,以下是一個簡單的前端實現(xiàn),演示了如何在用戶點擊發(fā)送驗證碼按鈕時觸發(fā)短信驗證碼的發(fā)送,并開始一個倒計時2024-04-04
vue+elementUI實現(xiàn)點擊左右箭頭切換按鈕功能
這篇文章主要介紹了vue+elementUI實現(xiàn)點擊左右箭頭切換按鈕功能,樣式可以根據(jù)自己需求改動,感興趣的朋友可以參考下實現(xiàn)代碼2024-05-05
在vue中利用全局路由鉤子給url統(tǒng)一添加公共參數(shù)的例子
今天小編就為大家分享一篇在vue中利用全局路由鉤子給url統(tǒng)一添加公共參數(shù)的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11
elementui源碼學(xué)習(xí)仿寫el-link示例詳解
這篇文章主要為大家介紹了elementui源碼學(xué)習(xí)仿寫el-link示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12
Vue.js實現(xiàn)一個todo-list的上移下移刪除功能
這篇文章主要介紹了Vue.js實現(xiàn)一個todo-list的上移下移刪除功能,需要的朋友可以參考下2017-06-06
vue項目如何使用$router.go(-1)返回時刷新原來的界面
這篇文章主要介紹了vue項目如何使用$router.go(-1)返回時刷新原來的界面問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09

