Study/Vue.js

[Vue.js] 05 Template

록씨 2021. 9. 23. 14:21
반응형

템플릿 문법

  • 렌더링 된 DOM을 기본 Vue 인스턴스의 데이터에 선언적으로 바인딩 할 수있는 HTML 기반 템플릿 구문을 사용한다.
  • 모든 Vue.js 템플릿은 스펙을 호환하는 브라우저 및 HTML 파서로 구문 분석 할 수있는 유효한 HTML이다.
  • 반응형 시스템과 결합된 Vue는 앱 상태가 변경 될 때 최소한으로 DOM을 조작하고 다시 적용할 수 있는 최소한의 컴포넌트를 지능적으로 파악할 수 있다.

 

데이터 바인딩

  • 뷰 인스턴스에서 정의한 속성들을 화면에 표시하는 방법

문자열

  • 가장 기본적인 데이터 바인딩 방식은 콧수염 괄호(Mustache Tag)
  • 속성이 변경될 때 마다 갱신된다.
  • v-once를 사용하여 데이터 변경 시 업데이트를 방지 할 수지만, 같은 노드의 바인딩에도 영향을 미친다는 점을 유의해야 합니다.
<div>{{ message }}</div>
new Vue({
  //delimiters: ['[[', ']]'],
  data: {
    message: 'Hello Vue.js'
  }
})

속성

  • Mustaches는 HTML 속성에서 사용할 수 없어서 v-bind 디렉티브를 사용한다.
    • <div v-bind:id="dynamicId"></div>
  • boolean 속성을 사용할 경우, 해당값이 false의 값을 가지면 disabled 속성은 렌더링 된<button>엘리먼트에 포함되지 않는다.
    • <button v-bind:disabled="isButtonDisabled">Button</button>

 

Javascript 표현식 사용

  • 모든 데이터 바인딩 내에서 JavaScript 표현식의 모든 기능을 지원
  • 각 바인딩에 하나의 단일 표현식 만 포함될 수 있다
{{ number + 1 }}  // O
{{ ok ? 'YES' : 'NO' }}  // O
{{ message.split('').reverse().join('') }}  // O
{{ var a = 1 }}  // X
{{ if (ok) { return message } }} // X

디렉티브

  • 뷰로 화면의 요소를 더 쉽게 조작하기 위한 문법
  • 화면 조작에서 자주 사용되는 방식들을 모아 디렉티브 형태로 제공
  • v- 접두사가 있는 특수 속성

조건

  • 데이터의 boolean 표현에 따라 엘리먼트를 제거 또는 삽입한다.
  • v-if, v-else-if, v-else
    • else-if 는 2.1.0에 추가됨
<div v-if="type === 'A'">
  A
</div>
<div v-else-if="type === 'B'">
  B
</div>
<div v-else-if="type === 'C'">
  C
</div>
<div v-else>
  Not A/B/C
</div>
  • v-show
    • display:none 옵션이 추가된다.
    • <h1 v-show="ok">안녕하세요!</h1>

 

리스트

  • v-for 리스트
    • items는 원본 데이터 배열이고 item은 반복되는 배열 엘리먼트의 변수이다.
<ul id="example-2">
   <li v-for="(item, index) in items">
     {{ parentMessage }} - {{ index }} - {{ item.message }}
   </li>
</ul>
  • v-for 객체
    • 객체의 속성을 반복할 수도 있다.
    • 객체를 반복할 때 순서는 `Object.keys()`의 키 나열 순서에 따라 결정된다.
new Vue({
   el: '#v-for-object',
   data: {
     object: {
         title: 'How to do lists in Vue',
         author: 'Jane Doe',
         publishedAt: '2016-04-10'
     }
   }
})
<div v-for="(value, name) in object">
 {{ name }}: {{ value }}
</div>

이벤트

  • v-on
    • DOM 이벤트를 수신
<button v-on:click="counter += 1">Add 1</button>
<a v-on:click="doSomething">...</a>

data: {
  counter: 0,
},
methods: {
  doSomething: function(event) {}
}
  • 수식어
    • 수식어를 통해 간단하게 여러 입력 이벤트를 감지할 수 있다.
    • 관련 코드가 동일한 순서로 생성되므로 수식어를 사용할 때 순서를 지정
    • 키 수식어도 가능하다.
<!-- 클릭 이벤트 전파가 중단됩니다 -->
<a v-on:click.stop="doThis"></a>

<!-- 제출 이벤트가 페이지를 다시 로드 하지 않습니다 -->
<form v-on:submit.prevent="onSubmit"></form>

<!-- 수식어는 체이닝 가능합니다 -->
<a v-on:click.stop.prevent="doThat"></a>

<!-- 단순히 수식어만 사용할 수 있습니다 -->
<form v-on:submit.prevent></form>


<!-- 키 수식어 -->
<input v-on:keyup.enter="submit">

바인딩

  • v-bind
    • 반응적으로 HTML 속성을 갱신하는데 사용
    • 데이터 바인딩은 엘리먼트의 클래스 목록과 인라인 스타일을 조작하기 위해 일반적으로 사용
<div v-bind:id="dynamicId"></div>
<a v-bind:href="url">...</a>
<p v-bind:class="{ warning: isError }">Hello</p>
<div class="static" v-bind:class="{ active: isActive, 'text-danger': hasError }"></div>

data: {
  dynamicId: 'AbcD',
  url: '[http://localhost.com](http://localhost.com)',
  isError: true,
  isActive: false,
  hasError: true
}

 

  • v-model
    • Input과 textarea 엘리먼트에 양방향 데이터 바인딩을 생성할 수 있다.
#문자열
<input v-model="message" placeholder="여기를 수정해보세요">
<p>메시지: {{ message }}</p>

#multi line 
<textarea v-model="message" placeholder="여러줄을 입력해보세요"></textarea>

#checkbox
<div id='example-3'>
 <input type="checkbox" id="jack" value="Jack" v-model="checkedNames">
 <label for="jack">Jack</label>
 <input type="checkbox" id="john" value="John" v-model="checkedNames">
 <label for="john">John</label>
 <input type="checkbox" id="mike" value="Mike" v-model="checkedNames">
 <label for="mike">Mike</label>
 <br>


 <span>체크한 이름: {{ checkedNames }}</span>
</div>

data: {
 checkedNames: []
}

#Radio
<input type="radio" id="one" value="One" v-model="picked">
<label for="one">One</label>
<input type="radio" id="two" value="Two" v-model="picked">
<label for="two">Two</label>

약어

  • 자주 사용되는 v-bind(:), v-on(@), v-slot(#) 은 약어가 존재한다
  • v-bind: -> :
<!-- 전체 문법 -->
<a v-bind:href="url"> ... </a>

<!-- 약어 -->
<a :href="url"> ... </a>

<!-- shorthand with dynamic argument (2.6.0+) -->
<a :[key]="url"> ... </a>
  • v-on: -> @
<!-- 전체 문법 -->
<a v-on:click="doSomething"> ... </a>

<!-- 약어 -->
<a @click="doSomething"> ... </a>

<!-- shorthand with dynamic argument (2.6.0+) -->
<a @[event]="doSomething"> ... </a>

 

computed 와 watch

computed

  • 템플릿 내에 표현식을 넣을수 있지만 간단한 연산일 때만 이용하는 것이 좋다. 너무 많은 연산을 템플릿 안에서 하면 코드가 비대해지고 유지보수가 어렵다.
  • 종속 대상을 따라 저장(캐싱)된다
  • 주로 validation 에 사용
<div id="example">
 <p>원본 메시지: "{{ message }}"</p>                  //안녕하세요
 <p>역순으로 표시한 메시지: "{{ reversedMessage }}"</p>  //요세하녕안
</div>
var vm = new Vue({
 el: '#example',
 data: {
     message: '안녕하세요'
 },
 computed: {
     / 계산된 getter
     reversedMessage: function () {
     // `this` 는 vm 인스턴스를 가리킵니다.
         return this.message.split('').reverse().join('')
     }
 }
})

watch

  • 대부분의 경우 computed 속성이 더 적합하지만 사용자가 만든 감시자가 필요한 경우가 있을 것이다.
  • 데이터 변경에 대한 응답으로 비동기식 또는 시간이 많이 소요되는 조작을 수행하려는 경우에 가장 유용하다
var vm = new Vue({
  el: '#example',
  data: {
     message: '안녕하세요'
  },
  computed: {
     / 계산된 getter
     reversedMessage: function () {
     // `this` 는 vm 인스턴스를 가리킵니다.
         return this.message.split('').reverse().join('')
     }
  },
  watch: {
    // 이전 데이터(old)와 갱신된 데이터(new) 모두 접근 가능하다.
    message: function(new, old) {
      axios.get();
    }
  }
})
반응형