帮我写一段简单的图片压缩上传的html代码
时间: 2023-08-04 16:05:31 浏览: 107
当然可以,下面是一个简单的图片压缩上传的 HTML 代码示例:
```html
<!DOCTYPE html>
<html>
<head>
<title>图片压缩上传</title>
</head>
<body>
<h1>图片压缩上传</h1>
<form enctype="multipart/form-data">
<input type="file" id="imageFile" accept="image/*">
<br>
<button type="button" onclick="compressAndUploadImage()">压缩并上传图片</button>
</form>
<br>
<img id="previewImage" src="" alt="预览图" style="max-width: 500px;">
<script>
function compressAndUploadImage() {
var imageFile = document.getElementById("imageFile").files[0];
var reader = new FileReader();
reader.onload = function (event) {
var image = new Image();
image.src = event.target.result;
image.onload = function () {
var canvas = document.createElement("canvas");
var context = canvas.getContext("2d");
var width = image.width;
var height = image.height;
if (width > height) {
if (width > 500) {
height *= 500 / width;
width = 500;
}
} else {
if (height > 500) {
width *= 500 / height;
height = 500;
}
}
canvas.width = width;
canvas.height = height;
context.drawImage(image, 0, 0, width, height);
var compressedImage = canvas.toDataURL("image/jpeg");
var xhr = new XMLHttpRequest();
xhr.open("POST", "/uploadImage", true);
xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xhr.onreadystatechange = function () {
if (xhr.readyState === 4 && xhr.status === 200) {
alert("上传成功!");
}
};
xhr.send("image=" + encodeURIComponent(compressedImage));
document.getElementById("previewImage").src = compressedImage;
};
};
reader.readAsDataURL(imageFile);
}
</script>
</body>
</html>
```
这段代码包含一个表单元素和一个 JavaScript 函数。用户可以通过表单元素选择一个图片文件,然后点击“压缩并上传图片”按钮触发 JavaScript 函数。该函数将图片文件读入内存,然后使用 HTML5 Canvas 对象将图片压缩到最大宽度或高度为 500 像素的尺寸,并将压缩后的图片转化为 Base64 编码的字符串。然后,该函数使用 Ajax 技术向服务器端发送 POST 请求,上传压缩后的图片数据。服务器端可以将该数据解码成二进制图片文件,然后保存到磁盘或者存储到数据库中。注意,这里使用了 `encodeURIComponent()` 方法对压缩后的图片数据进行编码,以便于通过 POST 请求发送。
阅读全文