vue3实现自定义指令
创建一个empty.js
import { nextTick } from 'vue'; const emptyImgUrl = new URL('@/assets/images/empty-icon.jpeg', import.meta.url).href; // 在vue3中不支持require引入静态图片,这是一种引入方式 另外一种是直接import const empty = { install(app, options) { app.directive('empty', (el, binding, vnode, oldVnode) => { nextTick(() => { let show = binding.value.show; let ElClass = binding.value.el; const _DOM = el.querySelector(`.${ElClass}`); if (!_DOM) { return; } if (show) { _DOM.style.display = 'block'; const empty_content = el.querySelector('.empty_content'); if (empty_content) empty_content.remove(); } else { _DOM.style.display = 'none'; let div = document.createElement('div'); div.className = 'empty_content'; div.style.height = '100%'; div.style.width = '100%'; div.style.display = 'flex'; div.style.alignItems = 'center'; div.style.justifyContent = 'center'; let img = document.createElement('img'); img.setAttribute('src', emptyImgUrl); div.appendChild(img); el.appendChild(div); } }); }); } }; export default empty;
在main.js在引入:
import empty from './directive/empty';
app.use(empty);
在具体页面使用:
<div v-empty="{ el: 'empty', show: false }"> <div class="empty"></div> </div>
这样就完成了vue3自定义指令!
希望大佬看到有不对的地方,提出博主予以改正!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异