--- title: FileReader.readAsDataURL() slug: Web/API/FileReader/readAsDataURL translation_of: Web/API/FileReader/readAsDataURL --- <div>{{APIRef("File API")}}</div> <p> </p> <p><code>readAsDataURL</code> 메서드는 컨텐츠를 특정 {{domxref("Blob")}} 이나 {{domxref("File")}}에서 읽어 오는 역할을 합니다. 읽어오는 read 행위가 종료되는 경우에, {{domxref("FileReader.readyState","readyState")}} 의 상태가 <code>DONE</code>이 되며, {{event("loadend")}} 이벤트가 트리거 됩니다. 이와 함께, base64 인코딩 된 스트링 데이터가 {{domxref("FileReader.result","result")}} 속성(attribute)에 담아지게 됩니다.</p> <h2 id="문법">문법</h2> <pre class="syntaxbox"><em>instanceOfFileReader</em>.readAsDataURL(blob);</pre> <h3 id="파라미터">파라미터</h3> <dl> <dt><code>blob</code></dt> <dd>읽고자 하는 {{domxref("Blob")}} 또는 {{domxref("File")}}.</dd> </dl> <h2 id="예제">예제</h2> <h3 id="HTML">HTML</h3> <pre class="brush: html"><input type="file" onchange="previewFile()"><br> <img src="" height="200" alt="이미지 미리보기..."></pre> <h3 id="JavaScript">JavaScript</h3> <pre class="brush: js">function previewFile() { var preview = document.querySelector('img'); var file = document.querySelector('input[type=file]').files[0]; var reader = new FileReader(); reader.addEventListener("load", function () { preview.src = reader.result; }, false); if (file) { reader.readAsDataURL(file); } }</pre> <h3 id="실행_결과">실행 결과</h3> <p>{{EmbedLiveSample("Example", "100%", 240)}}</p> <p> </p> <h2 id="복수의_파일_읽기_예제">복수의 파일 읽기 예제</h2> <h3 id="HTML_2">HTML</h3> <pre class="brush: html"><input id="browse" type="file" onchange="previewFiles()" multiple> <div id="preview"></div></pre> <h3 id="JavaScript_2">JavaScript</h3> <pre class="brush: js">function previewFiles() { var preview = document.querySelector('#preview'); var files = document.querySelector('input[type=file]').files; function readAndPreview(file) { // `file.name` 형태의 확장자 규칙에 주의하세요 if ( /\.(jpe?g|png|gif)$/i.test(file.name) ) { var reader = new FileReader(); reader.addEventListener("load", function () { var image = new Image(); image.height = 100; image.title = file.name; image.src = this.result; preview.appendChild( image ); }, false); reader.readAsDataURL(file); } } if (files) { [].forEach.call(files, readAndPreview); } } </pre> <div class="note"><strong>주의:</strong> <a href="/en-US/docs/Web/API/FileReader"><code>FileReader()</code></a> 생성자는 Internet Explorer 10 이전 버전에서는 지원하지 않는 기능입니다. 정상적으로 지원하는 코드를 확인하기 위해서는 다음 링크를 참조하시기 바랍니다. <a class="internal" href="https://mdn.mozillademos.org/files/3699/crossbrowser_image_preview.html" title="crossbrowser_image_preview.html">crossbrowser possible solution for image preview</a>. 또는 <a href="https://mdn.mozillademos.org/files/3698/image_upload_preview.html">this more powerful example</a>.</div> <h2 id="명세">명세</h2> <table class="standard-table"> <tbody> <tr> <th scope="col">명세</th> <th scope="col">상태</th> <th scope="col">비고</th> </tr> <tr> <td>{{SpecName("File API", "#FileReader-interface", "FileReader")}}</td> <td>{{Spec2("File API")}}</td> <td>Initial definition</td> </tr> </tbody> </table> <h2 id="브라우저_호환성">브라우저 호환성</h2> <p>{{Compat("api.FileReader.readAsDataURL")}}</p> <h2 id="바깥_고리">바깥 고리</h2> <ul> <li>{{domxref("FileReader")}}</li> </ul>