>  기사  >  웹 프론트엔드  >  HTML5 사진 업로드, 모바일 및 PC 단말기 공통 코드 공유

HTML5 사진 업로드, 모바일 및 PC 단말기 공통 코드 공유

黄舟
黄舟원래의
2018-05-16 13:57:495467검색

이 글은 모바일과 PC에서 이미지를 업로드하는 HTML5의 일반적인 코드에 대한 관련 정보를 주로 소개하고 있습니다. 매우 훌륭하고 참고할만한 가치가 있습니다.

더 이상 헛소리는 하지 마세요. 오늘 제가 여러분과 공유하고 싶은 것은 HTML5를 사용하여 이미지를 업로드하는 것입니다. 우리는 모바일 단말기에서 사용하지만 이것은 PC에서도 보편적으로 호환됩니다. Google에서만 테스트했습니다. "HTML5의 파일 API를 사용하여 업로드된 이미지를 미리보기"라는 내용이 Angle로 작성되었습니다. 오늘은 각도 관련 내용을 버리고 html5 + js 이미지 업로드 사례를 공유하겠습니다. 오늘은 특정 단계를 따라해 보겠습니다.

HTML5 사진 업로드, 모바일 및 PC 단말기 공통 코드 공유

HTML 첫 번째 단계는 html을 만드는 것입니다. 페이지에 파일 선택을 위한 input#upload를 배치합니다(PS: 저는 게으르고 여기서는 반복하지 않겠습니다.)

  1. <p class="con4">     
     <span class="btn upload">上传<input type="file" class="upload_pic" id="upload" /></span>     
    </p>

CSS참고: CSS가 약간 지저분합니다. , 그러니 이해가 안 되시면 저에게 물어보시거나 직접 작성하셔도 됩니다.

CSS Code复制内容到剪贴板
con{      
     width: %;      
     height: auto;      
     overflow: hidden;      
     margin: % auto  auto;      
     color: #FFFFFF;      
}      
con .btn{      
     width: %;      
     height: px;      
     line-height: px;      
     text-align: center;      
     background: #dbc;      
     display: block;      
     font-size: px;      
     border-radius: px;      
}      
upload{      
     float: left;      
     position: relative;      
}      
upload_pic{      
     display: block;      
     width: %;      
     height: px;      
     position: absolute;      
     left: ;      
     top: ;      
     opacity: ;      
     border-radius: px;      
}

Javascript

브라우저의 호환성을 확인하기 위해 getElementById를 통해 노드를 가져옵니다. FileReader를 지원하지 않는 경우 인터페이스 브라우저는 프롬프트를 표시하고 입력을 비활성화합니다. 그렇지 않으면 입력의 변경 이벤트를 수신합니다.

JavaScript Code复制内容到剪贴板
//获取上传按钮    
var input = document.getElementById("upload");       
if(typeof FileReader===&#39;undefined&#39;){       
     //result.innerHTML = "抱歉,你的浏览器不支持 FileReader";     
     input.setAttribute(&#39;disabled&#39;,&#39;disabled&#39;);       
}else{       
     input.addEventListener(&#39;change&#39;,readFile,false);       
}

그런 다음 file_input의 변경 이벤트가 트리거되면 함수 readFile()을 호출합니다. readFile에서는 먼저 파일객체를 가져온 다음 파일 유형속성을 통해 파일 유형을 감지합니다. 물론 이미지 유형 파일만 선택할 수 있습니다. newFileReader 인스턴스를 만들고 readAsDataURL 메서드를 호출하여 선택한 이미지 파일을 읽습니다. 마지막으로 onload 이벤트에서 성공적으로 읽은 파일 콘텐츠를 가져오고 선택한 이미지 파일이 표시됩니다. img 노드 그림을 삽입합니다.

JavaScript Code复制内容到剪贴板
function readFile(){       
     var file = this.files[];       
     if(!/image\/\w+/.test(file.type)){       
         alert("文件必须为图片!");       
         return false;       
     }       
     var reader = new FileReader();       
     reader.readAsDataURL(file);       
     //当文件读取成功便可以调取上传的接口,想传哪里传哪里(PS: 你们可以把你们的靓照偷偷发给我!)    
     reader.onload = function(e){       
         var data = this.result.split(&#39;,&#39;);      
         var tp = (file.type == &#39;image/png&#39;)? &#39;png&#39;: &#39;jpg&#39;;      
         var a = data[];      
         //需要上传到服务器的在这里可以进行ajax请求    
         ... ...      
     }      
};

이제 이미지 업로드 기능이 완성되었습니다. 관심 있으신 분들은 직접 시도해 보시고 이해가 안 되시거나 제가 실수한 부분이 있으면 연락주세요. FileReader 메서드 및 이벤트

HTML5 사진 업로드, 모바일 및 PC 단말기 공통 코드 공유

위 내용은 HTML5 사진 업로드, 모바일 및 PC 단말기 공통 코드 공유의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
이전 기사:HTML5의