干货--手把手撸vue移动UI框架: 图片预加载

473 阅读2分钟
原文链接: www.divpc.cn
chenyq 2018/06/05 16:13:15 干货--手把手撸vue移动UI框架: 图片预加载

前言

图片预加载:顾名思义,图片预加载就是在网页全部加载之前,提前加载图片。我们这个插件很简单,主要做一件事情:当图片加载的过程中加载失败,或者路径不存在或者路径为空的时候,显示我们默认的图片;如果图片正确加载就显示原本的图片。这样就避免图片加载失败的时候页面上出现裂图或者是空白,提升用户体验。

实现代码

具体的代码如下:

<template>
  <img class="r-image" :src="dataSrc">
</template>

<script>
export default {
  props: {
    src: {
      type: String,
      default: ''
    }
  },
  data () {
    return {
      dataSrc: ''
    }
  },
  methods: {
    init () {
      /* eslint-disable no-new */
      let img = new Image()
      img.src = this.src
      img.onload = () => {
        this.dataSrc = this.src
      }
    }
  },
  created () {
    this.init()
  }
}
</script>

其实代码很简单,给图片一张默认的图片,然后创建一个Image对象,用来加载图片,如果图片加载成功触发onload函数,改变图片的路径,这样就实现了一个图片预加载组件了。是不是很简单?