img

vue3+vite自定义指令文件,统一管理指令文件

2023-12-20 0条评论 423次阅读 JavaScript


指令文件

/src/directive/index.js

export default {
    install: function (app) {
        const directives = import.meta.glob('./**/index.js', { eager: true });
        for (const key in directives) {
            if (key === './index.js') return;
            const directive = directives[key];
            const name = key.replace(/\.\/|\/index.js/g, '');
            app.directive(name, directive.default || directive);
        }
    }
};

添加到main.js里面

// 自定义指令
import Directive from '@/directive';

const app = createApp(App);
app.use(Directive).use(router).mount('#app');

例如防抖指令

\src\directive\debounce\index.js

image.png

/**
 * 按钮防抖
 * 用法:<el-button v-debounce="submit">点击</el-button>
 */
export default {
    mounted(el, binding) {
        if (typeof binding.value !== 'function') {
            console.error('callback must be a function')
            return;
        }
        let timer = null
        el.__handleClick__ = function () {
            if (timer) {
                clearInterval(timer)
            }
            timer = setTimeout(() => {
                binding.value()
            }, 200)
        }
        el.addEventListener('click', el.__handleClick__)
    },
    beforeUnmount(el) {
        el.removeEventListener('click', el.__handleClick__)
    }
};

nuxt3如何创建指令呢

在 plugins 里面新建 directive.client.js,统一所有指令

src\plugins\directive.client.js

const modulesFiles = import.meta.glob('../utils/directives/*.js', { eager: true })
const directives = {}
for (const path in modulesFiles) {
    const moduleName = path.replace(/.*\/([^/]+)\.js$/, '$1')
    directives[moduleName] = modulesFiles[path].default
}
// 定义nuxt插件
export default defineNuxtPlugin((nuxtApp) => {
    // 通过循环注册所有指令
    for (const key in directives)
        nuxtApp.vueApp.directive(key, directives[key])
})

创建指令

src\utils\directives\money.js

/**
* 文本展示为金额:20 -> 20.00
*/
export default {
    mounted(el) {
        let text = el.textContent.trim()

        const hasTag = text.includes('¥')
        // 检查文本内容是否包含 '¥' 符号,如果包含则移除
        if (hasTag)
            text = text.replace('¥', '')

        // 检查文本内容是否是数字或可以转换为数字的字符串
        if (!isNaN(text)) {
            // 将文本内容转换为数字并四舍五入保留两位小数
            const roundedNumber = Number(text).toFixed(2)

            // 更新元素的文本内容为四舍五入后的值
            el.textContent = hasTag ? `¥${roundedNumber}` : roundedNumber
        }
    }
}
🏷️ #指令#nuxt3

💬 COMMENT


🦄 支持markdown语法

👋友