在网站中,图片的使用十分常见,而如何优化图片的加载已经成为了开发者们关注的重点之一。其中一个重要的优化就是图片懒加载,即在用户滚动网页时才加载可见区域的图片,而在
在网站中,图片的使用十分常见,而如何优化图片的加载已经成为了开发者们关注的重点之一。其中一个重要的优化就是图片懒加载,即在用户滚动网页时才加载可见区域的图片,而在未滚动到的区域则不加载,从而减轻页面的加载压力,提高用户体验。
在使用 Vue 框架时,利用它提供的指令,可以很方便地实现图片懒加载及占位图。
- 对于图片懒加载的实现,我们可以使用 Vue-lazyload 这个库。首先,需要使用 npm 安装该库:
npm i vue-lazyload -S
- 在 Vue 的入口文件 main.js 中引入该库,并进行配置:
import Vue from 'vue' import VueLazyload from 'vue-lazyload' Vue.use(VueLazyload, { preLoad: 1.3, // 预加载的宽高比,默认为 1,即 PhotoShop 中的 1:1 error: 'path/to/error.png', // 当加载图片失败时的占位图 loading: 'path/to/loading.gif', // 加载中时的占位图 attempt: 1 // 图片加载的尝试次数 })
其中,preLoad 是指定预加载的宽高比,例如如果你设置成 1.3,那么图片预先加载时,宽度会是目标宽度的 1.3 倍;error 和 loading 分别是加载失败和加载中时的图片占位图;attempt 是加载图片的尝试次数。
- 在需要懒加载的图片位置,将
src
属性替换为v-lazy
指令:
<img v-lazy="path/to/image.png">
- 在页面中指定需要启用懒加载的区域:
<template> <div class="container"> <div class="item" v-for="item in list"> <img v-lazy="item.src"> <!-- 图片使用懒加载 --> <p>{{ item.text }}</p> </div> </div> </template> <script> export default { data() { return { list: [ { src: 'path/to/image-1.png', text: '图片 1' }, { src: 'path/to/image-2.png', text: '图片 2' }, { src: 'path/to/image-3.png', text: '图片 3' } ] } }, mounted() { this.$nextTick(() => { // 启用懒加载 this.$lazyload(this.$refs.container) }) } } </script>
上述代码在页面中循环展示一个图片列表,每个图片都使用了懒加载,同时在 mounted
钩子函数中指定启用懒加载的区域为 container
模块,这样就可以实现图片懒加载。
- 关于占位图的制作,可以使用在线工具或者 PhotoShop 等工具,制作适合自己网站样式的占位图。
通过上述步骤,就可以很简单地实现 Vue 中图片懒加载及占位图的效果了,这样可以大大减轻网站的加载压力,提高用户的体验。