至此,我们便可以在页面中使用懒加载来优化用户体验了。
lazyLoad.html
在项目中引入 js 文件一般是如下这种模式:
懒加载:
当文件被需要时才被加载即 执行fn()时,多次执行fn()只会加载一次js文件
预加载:
文件会在浏览器空闲的时候提前加载,有兼容性问题需慎用
图片懒加原理
图片懒加载的原理很简单,就是我们先设置图片的data-set属性(当然也可以是其他任意的,只要不会发送http请求就行了,作用就是为了存取值)值为其图片路径,由于不是src,所以不会发送http请求。 然后我们计算出页面scrollTop的高度和浏览器的高度之和,如果图片举例页面顶端的坐标Y(相对于整个页面,而不是浏览器窗口)小于前两者之和,就说明图片就要显示出来了(合适的时机,当然也可以是 其他情况),这时候我们再将 data-set属性替换为src属性即可。
图片懒加载实现步骤:
1. 在main.js中导入Vant中的Lazyload指令并注册:
import Vue from 'vue'import { Lazyload } from 'vant' // 导入懒加载模块LazyloadVue.use(Lazyload) // 注册懒加载指令
2. 为van-image设置lazy-load指令属性
<!-- lazy-load设置图片懒加载,是一个自定义指令 --><van-image width="90" height="90" :src="item2" lazy-load/>