익명의 개발노트

[vue.js] URL.createObjectURL 을 이용한 이미지 처리 본문

코딩일기/TIL

[vue.js] URL.createObjectURL 을 이용한 이미지 처리

캡틴.JS 2020. 5. 13. 11:52
반응형

우선 설명하기전에 Blob에 대해서 설명하고 넘어가려 한다.

Blob: Binary Large Object의 줄임말로 써 이미지, 사운드 파일 같이 하나의 큰 파일을 의미하며,

이런 파일들은 특별한 방법으로 다루어야하며, 멀티미디어 객체들을 저장하기 위해 주로 사용한다. (Blob객체 참고)

<input type='file'>은 .files라는 것을 가지고, files는 File 객체(new File())의 콜렉션이다.

그리고 File객체는 Bolb를 확장해서 만들어 진 것이며, Blob를 쓸 수 있는 곳이면 File도 사용할 수 있다.

* 모든 DBMS가 BLOB를 지원하지는 않음.

 

input type="file" 로 이미지 미리보기 기능 구현시

reader 객체를 써서하는 dataURL방법과 URL 객체인 createObjectURL을 이용하는 방법이 있다.

dataUrl을 이용하면 값을 아래와 같은 값으로 받아온다. (* 기존 제 블로그 이미지 업로드 참고)

DataURL은 문자열이며, 그 문자열을 풀어서 아래와 같이 긴 내용으로 만들어 사용하며,

img src에 적용할 때 마다 문자열을 파싱해서 이미지로 만드는 작업을 하기(만들어진 객체 공유 안하며, 새로 만듦)

때문에 속도측면에서 느리다.

 

""

 

반면, createObjectURL을 활용하면 아래와 같이 blob객체의 url주소값으로 이미지를 불러 올 수 있다.

이렇게 생성된 주소는 메모리에 올라가 있기 때문에(Blob 객체를 바라봄)

객체를 새로 만들 필요없이 바로 가져다 쓰기때문에 속도측면에서도 빠르다.

아래 생성된 주소는 실제 서버에는 존재하지 않고, 해당 브라우저에서만 사용 가능한 URL이다.(브라우저 내에서만 사용하기 위한 URL) 

createObjectURL로 생성된 Blob 주소

<template>
 <div class="itemFileBox" ref="itemFileBox">
  <input type="file" 
         class="item-file-image" 
         id="uploadItemFile" 
         ref="uploadItemFile"
         @change="onFileSelected"
         accept="image/*"
  />
  <label for="uploadItemFile">
    <div class="wrapper-image" >
       <img ref="uploadItemImage">
    </div>      
  </label>
 </div>  
</template>
 
 onFileSelected(event){
      let image = event.target;

      if(image.files[0]){
                
        let itemImage = this.$refs.uploadItemImage; //img dom 접근
        
        itemImage.src = window.URL.createObjectURL(image.files[0]);//img src에 blob주소 변환
        
        this.itemImageInfo.uploadImages = itemImage.src; //이미지 주소 data 변수에 바인딩해서 나타내게 처리
        
        itemImage.width ='200'; // 이미지 넓이
        
        itemImage.onload = () => {
          window.URL.revokeObjectURL(this.src)  //나중에 반드시 해제해주어야 메모리 누수가 안생김.
        }
     
      }
    }

 

 

반응형
Comments