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自定义指令!

 
posted @   zaijinyang  阅读(356)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
点击右上角即可分享
微信分享提示