网站首页 > 开源技术 正文
Lazyload图片加载通常用在图片很多的项目里,需要翻好几页,如果一打开页面就将所有的图片加载出来,会耗费很多性能,以及会让用户等待较长时间,为了有一个更好的用户体验,Lazyload图片懒加载就应运而生。Lazyload让图片只有在可视区域时才会加载出来。
应用这个组件需要注意的点是,即便我们之前有安装和引入vant框架,但这个Lazyload需要重新安装重引用。
import VueLazyload from 'vue-lazyload' Vue.use(VueLazyload)
准备工作:
- 创建一个页面: Lazyload.vue
- 在router.js里配置Lazyload页面的路由
{ path: '/lazyload', name: 'lazyload', component: () => import('./views/Lazyload') }
- 在index.vue里添加一项
<a href="javascript:void(0)" @click="$router.push('/lazyload')"> <van-col span="6" class="marb20"> <van-icon name="pending-deliver" /> <div>Toast 图片懒加载</div> </van-col> </a>
至今为止呢,我们的首页显示的样式子是这样滴?不知道不觉间我们已经学完了33个组件了!哇噢,为自己欢呼一下吧!如果想看更多的内容,欢迎关注我,每天都有更新哈。
代码演示Lazyload 图片懒加载:
基本方法:
<img class="img" v-for="img in imageList" v-lazy="img" >
v-lazy: 懒加载的图片,其值为图片的路径。
data() { return { imageList: [ require('../assets/01.jpg'), require('../assets/02.jpg'), require('../assets/03.jpg'), require('../assets/04.jpg'), ] } },
就在演示这段代码时总是出错,说找不到指令,最后发现是vant又更新了,需要重新安装,这才成功。说明vant框架更新的频率很高,用着会越来越好用的。以上代码需要说明一点的是在data里引入图片的方式,如果直接引用路径会因为定位不到相对路径会出错,需require一下才可以。如图:
背景懒加载:
<div class="img" v-for="img in imageList" v-lazy:background-image="img" />
css部分:
.img { width: 100%; height: 300px; background-size: 100% }
背景图片也是可以懒加载的,只不过改成了v-lazy:background-image="img"。这里需要注意的一点是需要给这个容器定义宽度和高度以及background-size。背景图片显示不出来。
模块懒加载:
懒加载模块会用到lazy-component,需要在main.js里设置一下。
Vue.use(VueLazyload, { lazyComponent: true });
options有如下, options是在引入VueLazyload时设置:
loading: 加载时的图片
error: 错误时的图片
preload: 预加载高度的比例
azyComponent: 是否能懒加载模块
<lazy-component> <img class="img" v-for="img in imageList" v-lazy="img" > </lazy-component>
更多关于Lazyload应用方法可以看下官方文档
到目前为止呢,Lazyload就演示完了!庆祝一下我们又学完一个组件啦!
今天就到这里啦。休息休息一会儿吧?明天继续加油噢!加油
猜你喜欢
- 2024-09-08 vue2组件系列第四十二节:NavBar 导航栏
- 2024-09-08 从零开始学Python——使用Selenium抓取动态网页数据
- 2024-09-08 黑客突破macOS的安全防御,新型恶意软件正在偷偷的窃取你的文件
- 2024-09-08 Visa|实习面试|2022 暑假(visa issues)
- 2024-09-08 消息中间件RabbitMQ入门详解(消息中间件mq作用)
- 2024-09-08 vue2组件系列第二十二节:SwitchCell 开关单元格
- 2024-09-08 vue2组件系列第二十节:按钮式单选组件
- 2024-09-08 vue2组件系列第四十节:NoticeBar 通告栏
- 2024-09-08 vue2组件系列第二十六节:PasswordInput 密码输入框
- 2024-09-08 vue2组件系列第二十四节:多选式按钮
你 发表评论:
欢迎- 07-10公司网站建站选择:人工建站和源码建站分析
- 07-10多用途游戏娱乐新闻网站HTML5模板
- 07-10站长教你搭建属于自己的网站(搭建网站的步骤)
- 07-10php宝塔搭建部署实战响应式塑料封条制品企业网站模板源码
- 07-10自适应响应式汽车配件类网站源码 html5高端大气汽车网站织梦模板
- 07-10网站标签怎么设置?(网站标签怎么设置比较好)
- 07-10PageAdmin企业网站制作中踩过的坑
- 07-10豆包给我输出的html在线象棋源码(有点简单)
- 最近发表
- 标签列表
-
- jdk (81)
- putty (66)
- rufus (78)
- 内网穿透 (89)
- okhttp (70)
- powertoys (74)
- windowsterminal (81)
- netcat (65)
- ghostscript (65)
- veracrypt (65)
- asp.netcore (70)
- wrk (67)
- aspose.words (80)
- itk (80)
- ajaxfileupload.js (66)
- sqlhelper (67)
- express.js (67)
- phpmailer (67)
- xjar (70)
- redisclient (78)
- wakeonlan (66)
- tinygo (85)
- startbbs (72)
- webftp (82)
- vsvim (79)
本文暂时没有评论,来添加一个吧(●'◡'●)