사설은 : 복사 작업이를 사용할 필요가 있기 때문에, 다른 사람의 블로그 위대한 하나님을 순수하게 기반을 붙여, 그것은 사실, 단지 미래가 사용할 수 있도록, 그것을 기록 할, 방법 뻔뻔한 표절 복사됩니다.
원본 : https://blog.csdn.net/weixin_33957648/article/details/86251969
기초 지식
1. HTML5의 이해 파일리스트 객체와 파일 객체.
HTML5에서, 파일리스트 객체는 사용자가 선택한 파일의 목록을 나타냅니다. 파일 제어 내에서 multipe 속성을 추가하여 한 번에 여러 파일을 선택할 수 있습니다. 컨트롤의 사용자에 의해 선택된 각 파일에는 인
파일 오브젝트, 및 오브젝트 파일리스트 파일 오브젝트의리스트이다. 사용자를 대신하여 모든 파일을 선택합니다. 의이 속성은 파일 객체를 보라 간단한 데모를 살펴 보자. 다음 코드 :
<!DOCTYPE html>
<html>
<head>
<title>filesystem:URL</title>
</head>
<body>
<div>
<label>选择:</label>
<input type='file' multiple id="file" />
<input type="button" value="文件上传" onClick="showFile()" />
</div>
<script>
function showFile() {
var files = document.getElementById('file').files; // 返回所有被选择的文件
for (var i = 0, ilen = files.length; i < ilen; i++) {
// 打印出单个文件对象的信息
console.log(files[i]);
/*
* 打印的信息如下:
File {
lastModified: 1457946612000
lastModifiedDate: Mon Mar 14 2016 17:10:12 GMT+0800 (CST) {}
name: "test.html"
size: 796
type: "text/html"
webkitRelativePath: ""
*/
/* 如果上传的是一张图片的话,会返回如下信息的
File {
lastModified: 1466907500000
lastModifiedDate: Sun Jun 26 2016 10:18:20 GMT+0800 (CST) {}
name: "a.jpg"
size: 23684
type: "image/jpeg"
webkitRelativePath: ""
}
*/
/*
因此 如果需要判断该上传的文件是不是图像文件的话,可以根据type类型来判断如下:
var file = files[i];
if (!/image\/\w+/.test(file.type)) {
console.log('该文件不是图像文件');
} else {
console.log('该文件是图像文件');
}
但是如果只让传图片的话,可以在image控件添加一个属性 accept="image/*" 即可;我们可以如下写代码:
<input type='file' multiple accept = 'image/gif,image/jpeg,image/jpg,image/png' />
*/
}
}
</script>
</body>
</html>
2. Blob 오브젝트를 이해
중요 : HTML5는 원래 이진 데이터 파일 객체를 나타내는 Blob 객체가 실제로 Blob 객체를 상속 추가합니다.
Blob 객체는 Blob 객체의 길이를 나타내는 크기 속성 바이트, 블롭 유형 속성은 유형을 알 수없는 경우, 널 (null) 문자열이 반환됩니다, MIME 타입을 나타내고, 두 가지 속성이 있습니다.
다음 코드를 살펴 보자 :
<!DOCTYPE html>
<html>
<head>
<title>filesystem:URL</title>
</head>
<body>
<div>
<label>选择文件:</label>
<input type="file" id="file" />
<input type="button" value="显示文件信息" onClick="showFileType()" />
<p>文件字节长度: <span id="size"></span></p>
<p>文件类型:<span id="type"></span></p>
</div>
<script>
function showFileType() {
var file;
// 获取用户选择的第一个文件
file = document.getElementById('file').files[0];
var size = document.getElementById('size');
var type = document.getElementById('type');
// 显示文件字节的长度
size.innerHTML = file.size;
// 显示文件的类型
type.innerHTML = file.type;
// 打开控制台 查看返回的file对象
console.log(file);
}
</script>
</body>
</html>
참고 : 파일 물방울과 동시에 사용할 수 있습니다, FileReader를 블롭에서 데이터를 읽을 수 있습니다.
다음은 일부 사진은 base64로 인코딩 된 영상에 절대 경로 지 주소, 그리고 다음 base64 인코딩 BLOB 객체로 이미지를 변환합니다. 다음과 같이 코드입니다 :
<!DOCTYPE html>
<html>
<head>
<title>将以base64的图片url数据转换为Blob</title>
</head>
<body>
<script>
/**
* 将以base64的图片url数据转换为Blob
* @param urlData
* 用url方式表示的base64图片数据
*/
function convertBase64UrlToBlob(base64){
var urlData = base64.dataURL;
var type = base64.type;
var bytes = window.atob(urlData.split(',')[1]); //去掉url的头,并转换为byte
//处理异常,将ascii码小于0的转换为大于0
var ab = new ArrayBuffer(bytes.length);
var ia = new Uint8Array(ab);
for (var i = 0; i < bytes.length; i++) {
ia[i] = bytes.charCodeAt(i);
}
return new Blob( [ab] , {type : type});
}
/*
* 图片的绝对路径地址 转换成base64编码 如下代码:
*/
function getBase64Image(img) {
var canvas = document.createElement("canvas");
canvas.width = img.width;
canvas.height = img.height;
var ctx = canvas.getContext("2d");
ctx.drawImage(img, 0, 0, img.width, img.height);
var ext = img.src.substring(img.src.lastIndexOf(".")+1).toLowerCase();
var dataURL = canvas.toDataURL("image/"+ext);
return {
dataURL: dataURL,
type: "image/"+ext
};
}
var img = "https://img.alicdn.com/bao/uploaded/TB1qimQIpXXXXXbXFXXSutbFXXX.jpg";
var image = new Image();
image.crossOrigin = '';
image.src = img;
image.onload = function(){
var base64 = getBase64Image(image);
console.log(base64);
/*
打印信息如下:
{
dataURL: "data:image/png;base64,xxx"
type: "image/jpg"
}
*/
var img2 = convertBase64UrlToBlob(base64);
console.log(img2);
/*
打印信息如下:
Blob {size: 9585, type: "image/jpg"}
*/
}
</script>
</body>
</html>
참고 : HTML5에서 실제로 Blob 객체를 상속 원래 이진 데이터 파일 객체를 나타내는 Blob 오브젝트를 추가합니다. 따라서, 우리는 그림 파일 객체로 절대 주소를 사용할 수 있습니다.
그래서 우리는 파일 객체로 사진을 변환 절대 주소를 사용할 수 있습니다, 개발자는 나에게 절대 주소의 유일한 사진을 준, 그래서 우리는 항상 당신이 파일 객체로 설정하지 않는 경우, 이것을 사용, 파일 객체로 어떻게 사진을 절대 주소로 원 VAR 리더 = 새로운 FileReader를 ()가 문장 부호, 당신이 사용할 수 있도록, 불평 위 방울의 Blob 객체가 먼저 당신이 파일 작업 객체 파일 리더를 사용하여 객체로 변환 우리에게 말했다.