This is an old revision of the document!
Vue.js 다운로드
CDN 이용
<!-- development version, includes helpful console warnings -->
<script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
<!-- production version, optimized for size and speed -->
<script src="https://cdn.jsdelivr.net/npm/vue@2"></script>
Vue.js 기본 구조
<!DOCTYPE html>
<html lang="ko">
<head>
<meta charset="utf-8">
<title>Vue.js App</title>
<link href="main.css" rel="stylesheet">
</head>
<body>
<div id="app">
<!-- template 출력 -->
</div>
<script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
<script src="main.js"></script>
</body>
</html>
var app = new Vue({
el: '#app'
})
var app = new Vue({
el: '#app',
data: {
message: 'Hello Vue.js!'
}
})
var app = new Vue({
// el
el: '#app',
// data
data: {
message: 'Vue.js'
},
// computed
computed: {
computedMessage: function() {
return this.message + '!'
}
},
// lifecycle hooks
created: function() {
// something to what you do
},
// methods
methods: {
myMethod: function() {
// something to what you do
}
}
})
| Lifecycles |
| Methods | Timing |
| beforeCreate | 인스턴스가 생성되고, 리액티브 초기화가 일어나기 전 |
| created | 인스턴스가 생성되고, 리액티브 초기화가 일어난 후 |
| beforeMount | 인스턴스가 마운트되기 전 |
| mounted | 인스턴스가 마운트된 후 |
| beforeUpdate | 데이터가 변경되어 DOM에 적용되기 전 |
| updated | 데이터가 변경되어 DOM에 적용된 후 |
| beforeDestroy | Vue 인스턴스가 제거되기 전 |
| destroyed | Vue 인스턴스가 제거된 후 |
| errorCaptured | 임의의 자식 컴포넌트에서 오류가 발생했을 때 |
| v-bind 장식자 |
| 장식자 | 의미 |
| .prop | 속성 대신에 DOM 속성으로 바인딩, DOM 속성과 직접 바인딩 |
| .camel | 케밥케이스1) 속성 이름을 카멜 케이스로 변환 |
| .sync | 양방 바인딩 |
| 템플렛 제어 디렉티브 |
| 디렉티브 | 설명 |
| v-pre | 템플릿 컴파일 생략 |
| v-once | 한 번만 바인딩 |
| v-text | Mustache 대신 텍스트 콘텐츠로 렌더링 |
| v-html | HTML 태그를 그대로 렌더링 |
| v-cloak | 인스턴스 준비가 끝나면 제거 |
Event Handling
| 이벤트 장식자 |
| 장식자 | 설명 |
| .stop | event.stopPropagation()을 호출 |
| .prevent | event.preventDefault()를 호출 |
| .capture | 캡처 모드로 DOM 이벤트를 핸들 |
| .self | 이벤트가 해당 요소에서 직접 발생할 때만 핸들러를 호출 |
| .native | 컴포넌트의 루트 요소 위에 있는 네이티브 이벤트를 핸들 |
| .once | 한 번만 핸들 |
| .passive | {passive: true}로 DOM 이벤트를 핸들 |
| 클릭 이벤트 |
| 장식자 | 설명 |
| .left | 마우스 왼쪽 버튼으로 눌렀을 때만 핸들러 호출 |
| .right | 마우스 오른쪽 버튼으로 눌렀을 때만 핸들러 호출 |
| .middle | 마우스 중간 버튼으로 눌렀을 때만 핸들러 호출 |
| 키 코드 별칭 |
| 별칭 | 의미 |
| .enter | Enter(엔터) 키를 눌렀을 때 |
| .tab | Tab(탭) 키를 눌렀을 때 |
| .delete | Delete(딜리트) 키를 눌렀을 때 |
| .esc | ESC 키를 눌렀을 때 |
| .space | Space(스페이스) 키를 눌렀을 때 |
| .up | 화살표 위 키를 눌렀을 때 |
| .down | 화살표 아래 키를 눌렀을 때 |
| .left | 화살표 왼쪽 키를 눌렀을 때 |
| .right | 화살표 오른쪽 키를 눌렀을 때 |
| 시스템 장식자 |
| 별칭 | 의미 |
| .ctrl | Ctrl(컨트롤) 키가 눌린 경우 |
| .alt | Alt(안트) 키가 눌린 경우 |
| .shift | Shift(시프트) 키가 눌린 경우 |
| .meta | Meta(메타) 키가 눌린 경우 |
| v-model 장식자 |
| 장식자 | 의미 |
| .lazy | input 대신 change 이벤트 핸들링 |
| .number | 값을 숫자로 변환 |
| .trim | 값 양쪽에 있는 쓸데없는 공백 제거 |
new Vue({
// ..
watch: {
<감시할 데이터>: function(<새로운 값>, <이전 값>) {
// value가 변화했을 때 하고 싶은 처리
},
'item.value': function(newVal, oldVal) {
// 객체의 속성도 감시할 수 있음
},
list: {
handler: function(newVal, oldVal) {
// list가 변경될 때 하고 싶은 처리
},
deep: true, // 속성: deep, 값: Boolean, 네스트된 객체도 감시할지
immediate: true // 속성: immediate, 값: Boolean, 처음 값을 읽어 들이는 시점에도 호출할지
}
}
})
| 사용자 정의 디렉티브에서 사용할 수 있는 훅 |
| 메서드 이름 | 시점 |
| bind | 디렉티브가 처음 요소와 연결될 때 |
| inserted | 연결된 요소가 부모 Node에 삽입될 때 |
| update | 연결된 요소를 내포하고 있는 컴포넌트의 VNode가 변경되었을 때 |
| componetUpdated | 내포하고 있는 컴포넌트와 자식 컴포넌트의 VNode가 변경되었을 때 |
| unbind | 연결되어 있는 요소로부터 디렉티브가 제거될 때 |
| 훅 매개변수 |
| 매개변수 | 내용 |
| el | 디렉티브가 연결되어 있는 요소 |
| binding | 배인드된 값, 매개변수, 장식자가 들어 있는 객체 |
| vnode | 요소에 대응되는 VNode |
| oldVnode | 변경 이전의 VNode(update 또는 componentUpdated에서만 사용 가능) |
| binding의 속성 |
| 속성 | 설명 |
| arg | 매개변수 |
| modifiers | 장식자 객체 |
| value | 새로운 값 |
| oldValue | 이전 값(update 또는 componentUpdated에서만 사용 가능) |
| 트랜지션 클래스의 시점 |
| Enter 계열의 클래스 | 대상 요소가 DOM에서 삽입될 때의 트랜지션 페이즈 |
| .v-enter | 대상 요소가 DOM에 삽입되기 전에 추가되며, 트랜지션이 종료될 때 사라짐. Enter 액티브 상태 |
| .v-enter-to | 트랜지션이 실제로 시작될 때 추가되며, 트랜지션이 종료될 때 사라짐. Enter의 종료 완료 |
| .v-enter-active | 대상 요소가 DOM에 삽입되기 전에 추가되며, 트랜지션이 종료될 때 사라짐. Enter의 액티브 상태 |
| Leave 계열의 클래스 | 대상 요소가 DOM에서 제거될 때의 트랜지션 페이즈 |
| .v-leave | 트랜지션 시작 전에 추가되며, 트랜지션 개시 때는 사라짐. Leave 시작 상태 |
| .v-leave-to | 트랜지션 시작 전에 추가되어, 트랜지션이 종료되었을 때 사라짐. Leave 종료 상태 |
| .v-leave-active | 트랜지션 시작 전에 추가되어, 트랜지션이 종료되었을 때 사라짐. Leave의 액티브 상태 |
| Enter와 Leave 시점 변경 |
| 모드 | 동작 |
| in-out | Enter 트랜지션이 종료되고 나서 Leave 트랜지션 시작 |
| out-in | Leave 트랜지션이 종료되고 나서 Enter 트랜지션 시작 |
| 사용할 수 있는 트랜지션 훅 |
| Enter 계열 훅 | 시점 |
| before-enter | DOM에 요소가 추가되기 전 |
| enter | .v-enter가 있는 DOM에 요소가 추가된 후 |
| after-enter | 트랜지션이 끝나거나 또는 enter에서 done()을 호출한 후 |
| enter-cancelled | enter 페이즈가 중간에 취소되었을 때 |
| Leave 계열 훅 | 시점 |
| before-leave | 클래스가 추가되기 전 |
| leave | .v-leave가 추가된 후 |
| after-leave | DOM에서 요소가 제거된 후 또는 leave에서 done()을 호출한 후 |
| leave-cancelled | leave 페이즈가 중간에 취소되었을 때 |