百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

基于 Vue 开发的图片裁剪插件,简单好用、免费开源,支持 Vue3

ztj100 2025-01-31 16:21 13 浏览 0 评论

用户头像上传需要裁剪和压缩图片,这个 Vue 插件就能快速完成这样的开发需求。

关于 Vue Cropper

Vue Cropper 是一款实用的 JavaScript 图片裁剪插件,基于 Vue.js 实现了在 web 上对图片的放大缩小、旋转、拖选区域裁剪图片压缩上传等功能,API 也很简单,使用很方便。

Vue Cropper 插件的技术特性

  • 基于 Vue 开发,支持最新的 Vue 3.x,兼容 Vue 2.x
  • 支持 ViteTypeScript
  • 无论是输入和输出图片,图片数据类型都支持 base 64blob,对图片输入和导出上传处理很友好
  • 支持压缩图片大小,输出主流的 JPG / PNG / WebP 图片格式
  • 除了可以在 web 端使用,也支持在服务端使用

Vue Cropper 的使用场景

不知道大家有没有做过用户上传头像的需求,用户选择用作头像的图片时,图片来源可能是手机拍照的源文件,照片尺寸和占用空间都很大;也可能是网络下载的图片,往往需要进一步处理才能上传。好用的图片裁剪功能,既能满足用户编辑头像的需求,也能按需处理好图片,对后端头像的储存、读取节省资源。


Vue Cropper 开发上手体验和使用建议

安装 Vue Cropper

Vue Cropper 支持 npm 安装和直接在线引入使用:

# npm 安装
npm install vue-cropper

# yarn 安装
yarn add vue-cropper

// 在 Vue 3 中使用
import 'vue-cropper/dist/index.css'
import { VueCropper }  from "vue-cropper";
// 使用组件
<vueCropper
  ref="cropper"
  :img="option.img"
  :outputSize="option.size"
  :outputType="option.outputType"
></vueCropper>

在线引入 cdn 地址:

// 在线引入,需要新引入 vue.js
<script src="https://cdn.jsdelivr.net/npm/vue@3.2.1/dist/vue.global.js"></script>
<script src="https://cdn.jsdelivr.net/npm/vue-cropper@1.0.2/dist/vue-cropper.umd.js"></script>
// 初始化 Vue
const app = Vue.createApp({...});
// 使用插件
app.component('vue-cropper', window['vue-cropper'].VueCropper);

Vue Cropper 插件使用建议

Vue Cropper 图片裁剪插件支持下面功能:

  • 图片放大、缩小
  • 图片旋转
  • 拖动选区,按区域裁剪图片
  • 支持输入网络图片
  • 支持输入 JPG / PNG / WebP 格式图片

关于用户头像,基本的头像图片处理功能基本涵盖了,本文首发在「那些免费的砖」网站,文章页面中我都会放置官网链接,这次放的是 Vue Cropper Github 的项目主页,文档很清晰,也很简单,一个页面就包含了所有的 API 介绍看,也有很多代码例子,把插件集成到自己项目,也很容易,直观的在线 demo 在这里。

值得一说的是,上传图片功能一般都是从表单选择图片,得到图片文件的临时路径 tempPath 再提交到后端服务器上传,而 Vue Cropper 支持输出为 base64 和 blob 格式的图片,这两种类型对实现下载图片到本地或者上传至服务器,都很友好,比如微信小程序的云函数或者是 uniapp 的官方的上传组件就完全支持。

免费开源说明

Vue Cropper 是一个免费开源的 JavaScript 图片裁剪插件,基于 Vue.js 开发和使用,项目源码基于 MIT 开源协议托管在 Github 上,任何人都可以免费下载使用,也可以用于商业项目。

关注我,持续分享高质量的免费开源、免费商用的资源。

↓↓点击查看本次分享的网址。

Vue Cropper - 基于 Vue 开发的图片裁剪插件,简单好用、免费开源,支持 Vue2 和 Vue3|那些免费的砖

相关推荐

利用navicat将postgresql转为mysql

导航"拿来主义"吃得亏自己动手,丰衣足食...

Navicat的详细教程「偷偷收藏」(navicatlite)

Navicat是一套快速、可靠并价格适宜的数据库管理工具,适用于三种平台:Windows、macOS及Linux。可以用来对本机或远程的MySQL、SQLServer、SQLite、...

Linux系统安装SQL Server数据库(linux安装数据库命令)

一、官方说明...

Navicat推出免费数据库管理软件Premium Lite

IT之家6月26日消息,Navicat推出一款免费的数据库管理开发工具——NavicatPremiumLite,针对入门级用户,支持基础的数据库管理和协同合作功能。▲Navicat...

Docker安装部署Oracle/Sql Server

一、Docker安装Oracle12cOracle简介...

Docker安装MS SQL Server并使用Navicat远程连接

...

Web性能的计算方式与优化方案(二)

通过前面《...

网络入侵检测系统之Suricata(十四)——匹配流程

其实规则的匹配流程和加载流程是强相关的,你如何组织规则那么就会采用该种数据结构去匹配,例如你用radixtree组织海量ip规则,那么匹配的时候也是采用bittest确定前缀节点,然后逐一左右子树...

使用deepseek写一个图片转换代码(deepnode处理图片)

写一个photoshop代码,要求:可以将文件夹里面的图片都处理成CMYK模式。软件版本:photoshop2022,然后生成的代码如下://Photoshop2022CMYK批量转换专业版脚...

AI助力AUTOCAD,生成LSP插件(ai里面cad插件怎么使用)

以下是用AI生成的,用AUTOLISP语言编写的cad插件,分享给大家:一、将单线偏移为双线;;;;;;;;;;;;;;;;;;;;;;单线变双线...

Core Audio音频基础概述(core 音乐)

1、CoreAudioCoreAudio提供了数字音频服务为iOS与OSX,它提供了一系列框架去处理音频....

BlazorUI 组件库——反馈与弹层 (1)

组件是前端的基础。组件库也是前端框架的核心中的重点。组件库中有一个重要的板块:反馈与弹层!反馈与弹层在组件形态上,与Button、Input类等嵌入界面的组件有所不同,通常以层的形式出现。本篇文章...

怎样创建一个Xcode插件(xcode如何新建一个main.c)

译者:@yohunl译者注:原文使用的是xcode6.3.2,我翻译的时候,使用的是xcode7.2.1,经过验证,本部分中说的依然是有效的.在文中你可以学习到一系列的技能,非常值得一看.这些技能不单...

让SSL/TLS协议流行起来:深度解读SSL/TLS实现1

一前言SSL/TLS协议是网络安全通信的重要基石,本系列将简单介绍SSL/TLS协议,主要关注SSL/TLS协议的安全性,特别是SSL规范的正确实现。本系列的文章大体分为3个部分:SSL/TLS协...

社交软件开发6-客户端开发-ios端开发验证登陆部分

欢迎订阅我的头条号:一点热上一节说到,Android客户端的开发,主要是编写了,如何使用Androidstudio如何创建一个Android项目,已经使用gradle来加载第三方库,并且使用了异步...

取消回复欢迎 发表评论: