首页
归档
笔记
树洞
搜索
友言

文章详情

Interesting People Record Interesting.

/ JavaScript / 文章详情

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

Sonder
2023-12-20
2465字
6分钟
浏览 (2.2k)

指令文件

/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
       }
   }
}
下一篇 / 完美解决vue3 keep-alive多个路由使用同一个组件的缓存问题

🎯 相关文章

💡 推荐文章

🕵️‍♂️ 评论 (0)