吴志勇的博客 吴志勇的博客
  • h5

    • HTML5&CSS3
  • scss

    • css预处理语言
  • JavaScript

    • JavaScript教程
    • Ajax
    • ES6教程
    • NodeJS
    • Typescript
  • 框架

    • Jquery
    • VUE
    • React
  • Swing专题
  • java基础
  • javaweb
  • 框架
  • 数据库
  • netty
  • 设计模式
  • 微服务及架构
  • 云原生
  • maven
  • 单元测试
工具
我的
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

吴志勇

......
  • h5

    • HTML5&CSS3
  • scss

    • css预处理语言
  • JavaScript

    • JavaScript教程
    • Ajax
    • ES6教程
    • NodeJS
    • Typescript
  • 框架

    • Jquery
    • VUE
    • React
  • Swing专题
  • java基础
  • javaweb
  • 框架
  • 数据库
  • netty
  • 设计模式
  • 微服务及架构
  • 云原生
  • maven
  • 单元测试
工具
我的
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • HTML5&CSS3

  • CSS预处理语言

  • JavaScript

  • nodejs

  • webpack

  • VUE

    • vue2

      • 01 【Vue简介 初识Vue 模板语法和数据绑定】
      • 02 【el和data的两种写法 MVVM模型】
      • 03 【数据代理 事件处理】
      • 04 【计算属性 侦听属性】
      • 05 【绑定样式 条件渲染 列表渲染】
      • 06 【Vue数据监视 v-model双向绑定】
      • 07 【内置指令 自定义指令】
      • 08 【生命周期 组件】
      • 09 【CLI 初始化脚手架 Vue零碎的一些知识】
      • 10 【组件编码流程 组件自定义事件 全局事件总线】
      • 11 【组件通信】
      • 12 【nextTick 过渡与动画】
      • 13 【代理配置 插槽】
      • 14 【Vuex】
      • 15 【Vue-Router】
      • 16 【打包 图片懒加载】
        • 1.打包
        • 2.图片懒加载
    • vue3

  • react

  • Typescript
  • 前端
  • VUE
  • vue2
wuzhiyong
2024-09-22

16 【打包 图片懒加载】

# 16 【打包 图片懒加载】

# 1.打包

vue.config.js

module.exports = {
  //打包时不生成map文件(用来进行错误提示的文件,很占用空间)
  productionSourceMap: false,
  // 关闭ESLINT校验工具
  lintOnSave: false,
}
1
2
3
4
5
6
pnpm run build
1

# 2.图片懒加载

懒加载vue-lazyload插件官网 (opens new window) 插件的使用直接参考官方教程,很简单。

安装vue-lazyload插件

pnpm add vue-lazyload@1.3.3 --save-dev
1

在main.js中进行引用

import VueLazyload from "vue-lazyload";

//或者自定义配置插件
Vue.use(VueLazyload, {
preLoad: 1.3,
error: require('@/assets/image/error.png'),
loading: require('@/assets/image/loading.gif'),
attempt: 1
})

1
2
3
4
5
6
7
8
9
10

各个自定义配置属性含义:

image-20220720143240479

使用(将图片设置为懒加载 (opens new window))

<img v-lazy="psdimg" class="psd" />
1

注意: 当遇到是v-for循环的时候,或者用div包裹着img的时候,需要在div上面添加 v-lazy-container="{ selector: ‘img’ }"

<div v-lazy-container="{ selector: 'img' }">
  <img data-src="//aaa.com/img1.jpg">
  <img data-src="//aaa.com/img2.jpg">
  <img data-src="//aaa.com/img3.jpg">  
</div>
  
<!--或者这种:-->
 
 <div v-lazy-container="{ selector: 'img' }" v-html="content">
</div>
1
2
3
4
5
6
7
8
9
10

如果是这种情况的话,一定要使用 data-src 来指定路径,而不使用v-lazy。因为如果使用的是v-lazy的话,拿到了图片地址也会一直显示不出来。

上次更新: 2024-09-30 01:09:25

← 15 【Vue-Router】 01 【创建vue3项目】→

Copyright © 2020-2025 wuzhiyong
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式