iis服务器助手广告
返回顶部
首页 > 资讯 > 前端开发 > VUE >深入剖析VUE图片懒加载的黑科技
  • 0
分享到

深入剖析VUE图片懒加载的黑科技

文章的关键字:VUE图片懒加载性能优化 2024-02-13 18:02:48 0人浏览 佚名
摘要

: 目前浏览器图片懒加载的方式有两种,一种是针对 元素的懒加载,这种方式是浏览器层面实现的懒加载,另一种是基于 javascript 实现的懒加载,这种方式可以针对任何元素图片懒加载,操作简单,兼容性好,是较为为主流的图片懒加载方式。

:

目前浏览器图片懒加载的方式有两种,一种是针对 元素的懒加载,这种方式是浏览器层面实现的懒加载,另一种是基于 javascript 实现的懒加载,这种方式可以针对任何元素图片懒加载,操作简单,兼容性好,是较为为主流的图片懒加载方式。

Vue 中图片懒加载功能可用 元素提供,该元素可以控制图片的加载与展示。

元素的属性如下:
  • src 图片源地址
  • loading 图片加载状态,可选值有 "default", "lazy",默认值 "default"
  • placeholder 图片占位图源地址,默认值 "data:image/png;base64, empty"
  • error-image 图片加载错误时显示的图片源地址,默认值 "data:image/png;base64, X...4M=EAAAA...40=u...1..E...=4."
  • sizes 用于监听元素尺寸变化
  • srcList 图片的备用 src 数组
元素的事件如下:
  • success 图片加载成功时触发
  • error 图片加载失败时触发
  • load 图片加载中时触发
元素的插槽如下:
  • loading 图片加载中的内容
  • error 图片加载失败时的内容
  • default 图片加载成功的默认内容

以下是 VUE 图片懒加载的演示代码:

<template>
  <vue:img src="https://img.alicdn.com/00000/xx/xx/xx/xx-1.png" loading="lazy" placeholder="data:image/png;base64,d4d1d931b55de03f5d4f590b91f4537b51d931b55de03f5d4f590b91f453" error-image="data:image/png;base64, X...4M=EAAAA...40=u...1..E...=4." sizes="100vw" @success="handleSuccess" @error="handleError" @load="handleLoad">
    <template #loading>
      <div style="color:#99a9a9">图片加载中...</div>
    </template>
    <template #error>
      <div style="color:#99a9a9">图片加载失败,请重试</div>
    </template>
    <template #default>
      <img alt="图片内容"></img>
    </template>
  </vue:img>
</template>

<script>
  export default {
    methods: {
      handleSuccess(e) {
        // 图片加载成功时触发
      },
      handleError(e) {
        // 图片加载失败时触发
      },
      handleLoad(e) {
        // 图片加载中时触发
      }
    }
  }
</script>

希望本文对您有所帮助,如果有任何疑问,请尽管联系我们。

--结束END--

本文标题: 深入剖析VUE图片懒加载的黑科技

本文链接: https://www.lsjlt.com/news/564232.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作