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函数,改变图片的路径,这样就实现了一个图片预加载组件了。是不是很简单?