美文网首页
VUE 自定义指令-解决异常图片情况

VUE 自定义指令-解决异常图片情况

作者: 哑巴湖大水怪吖 | 来源:发表于2022-04-29 16:32 被阅读0次

    自定义指令

    注册自定义指令

    Vue.directive('指令名称', {
        // 会在当前指令作用的dom元素 插入之后执行
        // options 里面是指令的表达式
        inserted: function (dom,options) {
            
        }
    })
    

    首先定义第一个自定义指令 v-imagerror

    export const imagerror = {
      // 指令对象 会在当前的dom元素插入到节点之后执行
      inserted(dom, options) {
        // options是 指令中的变量的解释  其中有一个属性叫做 value
        // dom 表示当前指令作用的dom对象
        // dom认为此时就是图片
        // 当图片有地址 但是地址没有加载成功的时候 会报错 会触发图片的一个事件 => onerror
        dom.onerror = function() {
          // 当图片出现异常的时候 会将指令配置的默认图片设置为该图片的内容
          // dom可以注册error事件
          dom.src = options.value // 这里不能写死
        }
      }
    }
    

    在main.js完成自定义指令全局注册

    import * as directives from '@/directives'
    // 注册自定义指令
    // 遍历所有的导出的指令对象 完成自定义全局注册
    Object.keys(directives).forEach(key => {
      // 注册自定义指令
      Vue.directive(key, directives[key])
    })
    

    相关文章

      网友评论

          本文标题:VUE 自定义指令-解决异常图片情况

          本文链接:https://www.haomeiwen.com/subject/rpyyyrtx.html