vue3中实现图片压缩的示例代码

 更新时间:2024年02月03日 16:15:24   作者:开心点啦.  
图片压缩是一种比较便捷的压缩方式,本文主要介绍了vue3中实现图片压缩的示例代码,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧

首先,为什么需要进行图片压缩:

  • 减少页面加载时间:因为图片是页面中常见的资源之一,较大的图片会增加页面的加载时间,影响用户体验,压缩图片可以减小图片的文件大小,提升页面加载速度。
  • 节省网络流量:在移动设备或移动网络下,加载大型图片可能会消耗大量的网络流量,导致用户的流量费用增加,压缩图片可以降低文件大小,节省用户的流量费用。
  • 节约服务器带宽:压缩图片可以减少服务器带宽流量,当服务器响应客户端请求时,如果返回的是压缩过的图片,那么所需的传输时间和带宽流量,都会比原始图片少,这是因为压缩图片可以减小文件大小,来减少所需的传输时间和带宽流量,在一些大量传输图片的场景下,压缩图片可以减少服务器的带宽流量,从而减低服务器成本,并提升用户体验。
  • 减少网络拥堵:在网络拥堵的情况下,下载大型图片可能会占用较多的带宽资源,从而导致其他用户的访问速度变慢,压缩图片可以减小图片的文件大小,减少网络拥堵的情况。
  • 减少存储空间:对于需要大量存储图片的应用程序,如图片分享网站,在线相册等。压缩图片可以减少存储空间的占用,降低成本。
  • 保护隐私信息:一些照片中可能包含了一些隐私信息,如地理位置,时间,人脸等。如果不进行压缩,这些信息可能会被黑客或者不法分子利用,压缩图片可以消除或者减少这些信息,保护隐私安全。
  • 增加搜索引擎排名:搜索引擎越来越注重网站的速度和性能。压缩图片可以加快页面的加载速度,提高用户体验。从而增加搜索引擎的排名。

在理解了项目中为什么要使用图片压缩后,可以在vite环境中vue项目中,先进行不同类型图片的引入与使用操作。

第一步:在src的目录中assets文件夹下放置一些不同格式的图片(.jpg,.png,.webp,.svg)

这些文件有大有小,有的有86.9KB,有的有540KB

第二步:引入图片

<template>
    <img src="./assets/pig.webp" />
    <img src="./assets/cat.jpg" />
    <img src="./assets/cat.png" />
    <img src="./assets/dog.png" />
    <img src="./assets/vue.svg" />
</template>

运行

npm run dev

第三步:打开调试工具Network面板

勾选Disable cache选项进行无缓存的页面请求测试,以下则可以清楚的看到各个文件类型与尺寸的大小。

那么是否可以对assets中的图片资源进行自动的压缩处理呢???? 

第一步:在vue项目中安装以下插件

npm i vite-plugin-image-optimizer -D

第二步:在vite.config.ts中引入模块并配置插件使用

import { defineConfig } from "vite";
import vue from "@vitejs/plugin-vue";
import { ViteImageOptimizer } from "vite-plugin-image-optimizer";

export default defineConfig({
    plugins:[
        vue(),
        ViteImageOptimizer()
    ],
});

vite-plugin-image-optimizer不支持开发环境图片压缩,需要利用npm run build进行生产环境项目打包。

运行完毕以后,在终端中会显示图片压缩的报表结果,清晰的可以查看到,如果原图可以进行压缩,包括压缩后的文件大小尺寸都有所显示。如果插件尝试对原图压缩,但压缩后的文件反而比原图大的话,那么将会采用skip的跳过机制,保留原图而不使用压缩操作。

如果觉得vite-plugin-image-optimizer默认配置不能够满足项目对图片优化的需求,则可以考虑进行自定义属性的设置。

比如:

对jpg进行压缩,画质保留至90%。对png进行压缩,画质保留至100%。

import { defineConfig } from "vite";
import vue from "@vitejs/plugin-vue";
import { ViteImageOptimizer } from "vite-plugin-image-optimizer";

export default defineConfig({
    plugins:[
        vue(),
        ViteImageOptimizer({
            jpg:{
                quality:90,
            },
            png:{
                quality:100,
            }
        })
    ],
});

执行npm run build打包命令以后则会看到与之前默认配置不同的压缩结果。

项目在打包以后会产生dist目录,确保电脑环境中有类似serve这样的本地服务开启工具以后,可以尝试在项目根目录运行serve ./dist

如果没有serve则可以进行下载:

npm install serve -g  全局安装

那么以上则是压缩前和压缩后图片大小的对比,那么在产品项目中的图片已经变得精简太多。 

到此这篇关于vue3中实现图片压缩的示例代码的文章就介绍到这了,更多相关vue3 图片压缩内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue.js 嵌套循环、if判断、动态删除的实例

    vue.js 嵌套循环、if判断、动态删除的实例

    下面小编就为大家分享一篇vue.js 嵌套循环、if判断、动态删除的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-03-03
  • Vue3组件传参的多种方式小结

    Vue3组件传参的多种方式小结

    这篇文章主要介绍 Vue3组件传参的方式,包括父子组件、跨层级组件、兄弟组件的传参,如父子组件通过属性绑定和自定义事件双向传参,跨层级组件可利用 Provide/Inject 机制和 Pinia 状态管理,兄弟组件可通过父组件中转或 mitt 库直接传参,需要的朋友可以参考下
    2025-01-01
  • vue中同时监听多个参数的实现

    vue中同时监听多个参数的实现

    这篇文章主要介绍了vue中同时监听多个参数的实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • 深入理解Vue nextTick 机制

    深入理解Vue nextTick 机制

    这篇文章主要介绍了深入理解Vue nextTick 机制,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • 2种在vue项目中使用百度地图的简单方法

    2种在vue项目中使用百度地图的简单方法

    在本篇文章中我们给大家整理了2种关于VUE项目中使用百度地图的最简单的方法,非常实用,一起来学习下。
    2018-09-09
  • vue设置导航栏、侧边栏为公共页面的例子

    vue设置导航栏、侧边栏为公共页面的例子

    今天小编就为大家分享一篇vue设置导航栏、侧边栏为公共页面的例子,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-11-11
  • Vue3框架使用报错以及解决方案

    Vue3框架使用报错以及解决方案

    这篇文章主要介绍了Vue3框架使用报错以及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • 详解在vue-test-utils中mock全局对象

    详解在vue-test-utils中mock全局对象

    这篇文章主要介绍了详解在vue-test-utils中mock全局对象,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-11-11
  • vue draggable resizable 实现可拖拽缩放的组件功能

    vue draggable resizable 实现可拖拽缩放的组件功能

    这篇文章主要介绍了vue draggable resizable 实现可拖拽缩放的组件功能,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-07-07
  • vue3中reactive和ref的实现与区别详解

    vue3中reactive和ref的实现与区别详解

    reactive和ref都是vue3实现响应式系统的api,他们是如何实现响应式的呢,reactive和ref又有什么区别呢,下面小编就来和大家详细讲讲,希望对大家有所帮助
    2023-10-10

最新评论