4.将压缩后的图片传给服务器
<div class="container"> <input type="file" id="upload" /> </div> const ACCEPT = ['image/jpg', 'image/png', 'image/jpeg'] // 所能接受的类型(自定义) const MAXSIZE = 3 * 1024 * 1024 // 上传图片大小限制(自定义) const MAXSIZE_STR = '3MB' const upload = document.getElementById('upload') upload.addEventListener('change', (e) => { const [file] = e.target.files if (!file) return // 上传文件为空时终止 const { type: fileType, size: fileSize } = file // 类型判断 if (!ACCEPT.includes(fileType)) { alert('不支持' + fileType + '文件类型') upload.value = '' return } // 图片大小判断 if (fileSize > MAXSIZE) { alert(`文件超出${MAXSIZE_STR}限制`) upload.value = '' return } // 压缩图片 covertImageToBase64(file, (base64Image) => compress(base64Image, uploadServer) ) })当所有限制都通过之后,就要将图片转为base64格式,也就是进入到covertImageToBase64函数,我们来看看这个函数做了什么。
function covertImageToBase64(file, callback) { let reader = new FileReader() reader.readAsDataURL(file) // 读取二进制数据,并将其编码为 base64 的 data url // 读取完成进行下面操作 reader.addEventListener('load', function (e) { const base64Image = reader.result callback && callback(base64Image) // 将读取到的结果传递给回调函数中 reader = null }) }这里我们要将上传获取的_file_进行编码转换,通过FileReaader[1]构造函数中的 readAsDataURL[2]方法进行转换,将编码后的格式文件传递给回调函数中准备进行压缩处理。
function compress(base64Image, callback) { let maxW = 800 // 图片最大宽度 let maxH = 800 // 图片最大高度 const image = new Image() image.src = base64Image document.body.appendChild(image) image.addEventListener('load', function (e) { let ratio // 图片压缩比 let needCompress = false // 是否需要压缩 // 按照比例进行图片宽高的修改 if (image.naturalWidth > maxW ) { needCompress = true ratio = image.naturalWidth / maxW maxH = image.naturalHeight / ratio } if (maxH < image.naturalHeight) { needCompress = true ratio = image.naturalHeight / maxH maxW = image.naturalWidth / ratio } if (!needCompress) { maxH = image.naturalHeight maxW = image.naturalWidth } const canvas = document.createElement('canvas') canvas.setAttribute('id', '__compress__') canvas.width = maxW canvas.height = maxH canvas.style.visibility = 'hidden' document.body.appendChild(canvas) const ctx = canvas.getContext('2d') ctx.clearRect(0, 0, maxW, maxH) ctx.drawImage(image, 0, 0, maxW, maxH) const compressImage = canvas.toDataURL('image/png', 0.9) callback && callback(compressImage) // console.log(compressImage) canvas.remove() }) } function uploadServer(compressImage) { console.log(`upload to server ${compressImage}`) }代码分析