이 글에서는 주로 HTML5에서 이미지의 절대 경로를 파일 객체로 변환하는 방법을 소개합니다. 편집자는 꽤 좋다고 생각해서 지금 공유하고 참고용으로 올려드리겠습니다. 편집자를 따라 살펴보겠습니다. 모두에게 도움이 되기를 바랍니다.
이미지의 절대 경로를 base64 인코딩으로 변환하려면 이 글을 읽어주세요
먼저 기본 지식 포인트를 이해합시다:
1 HTML5의 FileList 개체와 파일 개체를 이해합니다.
HTML5에서 FileList 객체는 사용자가 선택한 파일 목록을 나타냅니다. multipe 속성을 추가하면 파일 제어 내에서 여러 파일을 한 번에 선택할 수 있습니다. 컨트롤에서 사용자가 선택한 각 파일은 파일 개체이고 FileList 개체는 파일 개체 목록입니다. 사용자가 선택한 모든 파일을 나타냅니다. 먼저 간단한 데모를 통해 파일 객체에 어떤 속성이 있는지 살펴보겠습니다. 다음 코드:
<!DOCTYPE html> <html> <head> <title>filesystem:URL</title> </head> <body> <p> <label>选择:</label> <input type='file' multiple id="file" /> <input type="button" value="文件上传" onClick="showFile()" /> </p> <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 객체에는 두 가지 속성이 있습니다. size 속성은 Blob 객체의 바이트 길이를 나타내고, type 속성은 Blob의 MIME 유형을 나타냅니다.
다음 코드를 참조하세요:
<!DOCTYPE html> <html> <head> <title>filesystem:URL</title> </head> <body> <p> <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> </p> <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>
참고: Blob과 File은 동시에 사용할 수 있으며 FileReader를 사용하여 Blob에서 데이터를 읽을 수 있습니다.
다음은 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: "" type: "image/jpg" } */ var img2 = convertBase64UrlToBlob(base64); console.log(img2); /* 打印信息如下: Blob {size: 9585, type: "image/jpg"} */ } </script> </body> </html>
참고: HTML5에서는 원래 바이너리 데이터를 나타내기 위해 새 Blob 개체가 추가되었습니다. 실제로 파일 개체도 Blob 개체를 상속합니다. 따라서 이미지의 절대 주소를 사용하여 이미지를 파일 객체로 변환할 수 있습니다.
그래서 사진의 절대 주소를 사용하여 파일 개체로 변환할 수 있습니다. 자세한 데모를 보려면 플러그인이 먼저 사진 업로드를 지원하다가 갑자기 이를 발견했습니다. 편집 페이지로 이동하면 기본 사진이 표시되어야 합니다. 기본적으로 이미지를 표시하면서 새 이미지를 업로드하거나 모든 이미지를 삭제할 수도 있습니다. 하지만 개발자가 이미지의 절대 주소만 제공했기 때문에 이미지의 절대 주소를 파일 객체로 변환하는 방법이 궁금합니다. 파일 객체로 변환하지 않으면 이 코드를 사용할 때 var reader = new FileReader(); 를 사용할 수 있습니다. 위에서 설명한 blob 개체를 먼저 blob 개체로 변환한 다음 파일 작업 개체 fileReader를 사용할 수 있습니다.
관련 권장 사항:
Javascript는 이미지의 절대 경로를 base64 인코딩으로 변환합니다.
HTML 상대 경로와 절대 경로의 차이점에 대한 자세한 분석
위 내용은 HTML5에서 이미지의 절대경로를 파일객체로 변환하는 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!