首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

前端图片压缩及上传

压缩方案 前端图片压缩的主要思路就是将图片绘制到canvas中,然后通过canvas的toDataURL方法来控制图片的质量,对图片进行压缩,另一方面是对图片进行宽高等比缩小来达到图片压缩的效果,下面来看一下代码示例...,我们通过new 一个Blob对象,将其转换为Blob对象,然后就可以通过url方法来将其转换为可以放到img src中的链接形式了。...当压缩完成后返回的数据就是base64的数据了,我们就可以通过ajax异步来进行上传,在此我采用的是axios进行异步上传,将内容及文件名作为参数传递给后台。...= imgData.replace(/^data:image\/\w+;base64,/, ""); //var size = Buffer.byteLength(base64Data,'base64...; } }); }) 接口中我们通过Buffer来将base64转换为buffer,进而保存到服务器本地中,本示例采用的就是将图片保存到服务器本地。

2.9K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Vue解析剪切板图片并实现发送功能

    实现思路 页面挂载时监听剪切板粘贴事件 监听文件流 读取文件流中的数据 创建img标签 将获取到的base64码赋值到img标签的src属性 将生成的img标签append到即将发送的消息容器里 监听回车事件...上传成功后,将服务器返回的图片地址推送到websocket服务 客户端收到推送后,渲染页面 实现过程 本片文章主要讲解剪切板图片的解析以及将base64图片转换成文件上传至服务器,下方代码中的axios...完善消息发送函数,获取输入框里的所有子元素,找出base64图片将其转为文件并上传至服务器(此处需要注意:base64转文件时,需要用正则表达式删掉base64图片的前缀),将当前图片地址推送至websocket...图片的前缀 base64Img = base64Img.replace(/^data:image\/\w+;base64,/, "");...) { // 转换为byte let bytes = window.atob(urlData); // 处理异常,将ascii码小于0的转换为大于0 let ab = new ArrayBuffer

    1.5K20

    JS 图片压缩

    压缩思路 涉及到 JS 的图片压缩,我的想法是需要用到 Canvas 的绘图能力,通过调整图片的分辨率或者绘图质量来达到图片压缩的效果,实现思路如下: 获取上传 Input 中的图片对象 File 将图片转换成...}; }; }, // base64 图片转 blob 后下载 downloadImg() { let parts = this.compressImg.split...,不喜欢用 Vue 的也可以把代码稍微调整一下,下面开始具体分解一下代码的实现思路 Input 上传 File 处理 将 File 对象通过 FileReader 的 readAsDataURL 方法转换为...// base64 图片转 blob 后下载 downloadImg() { let parts = this.compressImg.split(';base64,'); let contentType...数据拆分后,通过 atob 方法解码 将解码后的数据转换成 Uint8Array 格式的无符号整形数组 转换后的数组来生成一个 Blob 数据对象,通过 URL.createObjectURL(blob

    25.8K21

    图片压缩原理

    压缩思路 涉及到 JS 的图片压缩,我的想法是需要用到 Canvas 的绘图能力,通过调整图片的分辨率或者绘图质量来达到图片压缩的效果,实现思路如下: 获取上传 Input 中的图片对象 File 将图片转换成...}; }; }, // base64 图片转 blob 后下载 downloadImg() { let parts = this.compressImg.split...,不喜欢用 Vue 的也可以把代码稍微调整一下,下面开始具体分解一下代码的实现思路 Input 上传 File 处理 将 File 对象通过 FileReader 的 readAsDataURL 方法转换为...// base64 图片转 blob 后下载 downloadImg() { let parts = this.compressImg.split(';base64,'); let contentType...数据拆分后,通过 atob 方法解码 将解码后的数据转换成 Uint8Array 格式的无符号整形数组 转换后的数组来生成一个 Blob 数据对象,通过 URL.createObjectURL(blob

    4.7K31

    base64编码图片数据存储服务器

    后来查阅资料,看见一个不错的解决方式就是将base64编码的图片数据转换为Blob(与File相似)并添加到form中提交。...编码转换为Blob //append函数的第一个参数是后台获取数据的参数名,和html标签的input的name属性功能相同 formData.append("ImgBase64",...} }); } /** * 将以base64的图片url数据转换为Blob * @param urlData * 用url方式表示的base64图片数据 */ function...( [ab] , {type : 'image/png'}); } 最后注意的是,因为提交到后台的是Blob类型的数据,没有文件名称,需要强制重新命名名称及类型。...accessory.setUuidFileName(map.get("newFilePath")); //取出上传文件大小 accessory.setValueSize(map.get("valueSize")); //将资源附件进行存储并返回附件关联代码

    1.8K20

    H5上传图片

    压缩上传 H5 如何解决 FileReader canvas FileReader FileReader可以将File对象转化成base64,这样可以优先展示图片,然后处理上传操作。...var img = new Image(); img.src = base64; img.onload = function(){ var canvas = document.createElement...使用mqq接口拍照或者获取本地图片时,反馈都是base64格式,input在处理过程中,经过压缩等操作也可能将File对象转化成base64,对base64的上传支持有以下方案: server支持,单独开接口处理...base64上传 前端将base64转化成File对象,复用原来的server接口 这里重点讨论第2中方案。...JS提供了Blob对象,是一个类文件对象,File对象继承了Blob对象,并且做了一些扩展。基于此,只需要把base64转化成Blob对象即可。Blob的构造参考这里,可以使用类型数据来处理。

    83210
    领券