남과 같이 해선 남 이상이 될 수 없다.

Vue

[Vue.js] Getter ,Setter

맨동 2021. 6. 29. 13:35
728x90

Getter, Setter

1. Getter

computed에 만들어놓은 reversedMessage라는 하나의 계산된 데이터는 읽기 전용(Read only)입니다. 즉, 우리가 할당 연산자로 어떤 값을 할당하더라도 반응적으로 동작할 수 있는 구조가 아닙니다. 그러므로 내부의 기본적인 로직을 통해서 값을 얻어낼 수 있는 용도, getter로만 사용이 가능합니다.

<script>
export default {
  computed: {
    // Getter
    reversedMessage() {
      return this.msg.split('').reverse().join('')
    }
  },
    methods: {
    add() {
      this.reversedMessage += '!?' // 실행되지 않음
    }
  }
}
</script>

2. Setter

이와 달리 data는 getter뿐만 아니라 setter로도 사용할 수 있습니다. 쉽게 말해 값을 읽을 수도 있으며, 여기에 더해 값을 지정할 수도 있습니다.

<script>
export default {
  data() {
    return {
      // Getter, Setter
      msg: 'Hello Computed'
    }
  }
methods: {
    add() {
      this.msg += '!?' // 실행됨
    }
  }
}

3. Computed도 setter가 가능

그러나 Vue.js 문법으로 computed 데이터도 setter 기능이 가능하도록 만들 수 있습니다.

그 방법은 computed 데이터를 메소드 형식으로 만드는 것이 아니라 하나의 객체 데이터를 할당하는 속성으로 만드는 것입니다. 그리고 그 속성 안에 get(), set()메소드로 코드를 작성해주는 겁니다.

<script>
export default {
  computed: {
    // Getter, Setter
    reversedMessage: {
      get() {
        return this.msg.split('').reverse().join('')
      },
      set(value) {
        this.msg = value
      }
    }
  },
  methods: {
    add() {
      this.reversedMessage += '!?'
    }
  }
}
</script>

getter에는 기본 로직을 추가하고,

setter에는 인수로 들어오는 값을 명시해줄 수 있습니다.

그러므로 위의 set(value)와 같이 매개변수로 이름을 지정해주시면 됩니다.

728x90

'Vue' 카테고리의 다른 글

[Vue.js] 클래스와 스타일 바인딩  (0) 2021.06.30
[Vue.js] Watch  (0) 2021.06.30
[Vue.js] Computed 와 Computed 캐싱  (0) 2021.06.29
[Vue.js] 템플릿 문법  (0) 2021.06.29
[Vue.js] 조건문과 반복문  (0) 2021.06.29