> 웹 프론트엔드 > JS 튜토리얼 > javascript HTML5 파일 업로드 FileReader API_javascript 팁

javascript HTML5 파일 업로드 FileReader API_javascript 팁

WBOY
풀어 주다: 2016-05-16 15:06:57
원래의
2106명이 탐색했습니다.

파일 업로드 기능은 이제 점점 일반화되고 있습니다. Youku Video, Weibo 등 모든 소셜 네트워킹 사이트는 사진 및 비디오 업로드와 같은 기능을 제공합니다. 그러나 과거에 웹 프로그래머들은 HTML 양식을 사용하여 파일을 업로드하는 것이 매우 번거롭다는 것을 알고 있었습니다. 특히 사용자가 업로드한 파일의 일부 속성을 알고 싶다면 업로드가 완료될 때까지 기다려야 합니다.

알 수 없는 것을 서버에 업로드하면 보안 문제가 발생할 수도 있고, 너무 커서 허용 크기를 초과하여 공간을 낭비할 수도 있습니다. 이제 WEB 기술은 발전하고 있으며 HTML5는 많은 좋은 것들을 가져왔습니다. 이 FileReader API를 사용하면 사용자가 업로드하기 전에 업로드된 파일의 일부 기본 속성을 얻을 수 있습니다.

HTML 코드

이 FileReader API는 File API와 동일하게 작동하며 input[type="file"] 요소를 사용해야 합니다.

<-- 一个能上传多媒体文件的表单 -->
<input type="file" id="upload-file" multiple />

<-- 显示图片的地方 -->
<div id="destination"></div>

로그인 후 복사

파일 API 글에는 주소, 볼륨, 크기, 파일 형식 등 읽을 수 있는 파일에 대한 자세한 정보가 나와 있습니다.

자바스크립트

이 예에서는 입력 양식 필드를 사용하여 사진을 업로드합니다. 사용자가 자신의 컴퓨터에서 사진을 선택하면 해당 사진이 페이지에 표시됩니다.

document.getElementById('upload-file').addEventListener('change', function() {
 var file;
 var destination = document.getElementById('destination');
 destination.innerHTML = '';

 // 循环用户多选的文件
 for(var x = 0, xlen = this.files.length; x < xlen; x++) {
 file = this.files[x];
 if(file.type.indexOf('image') != -1) { // 非常简单的交验

  var reader = new FileReader();

  reader.onload = function(e) {
  var img = new Image();
  img.src = e.target.result; // 显示图片的地方

  destination.appendChild(img);
  };
  
  reader.readAsDataURL(file);
 }
 }
});
로그인 후 복사

이 예에서는 FileReader의 readAsDataURL 메서드를 사용하여 이미지 콘텐츠를 base64로 인코딩된 문자열로 변환한 다음 이미지의 데이터 URI를 사용하여 표시합니다. 다른 FileReader 읽기 방법으로는 readAsText, readAsArrayBuffer 및 readAsBinaryString 등이 있습니다.

이 FileReader API를 사용하면 사용자가 먼저 서버에 파일을 업로드하는 것을 방지하고 브라우저 클라이언트에서 해당 파일을 작동할 수 있습니다. 서버에 업로드하기 전 이러한 전처리가 필요합니다.

위 내용은 이 글의 전체 내용입니다. 모든 분들의 공부에 도움이 되었으면 좋겠습니다.

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿