beforeCreate : 인스턴스가 생성되고 나서 가장 처음으로 실행되는 라이프 사이클 단계, data속성과 methods 속성이 아직 정의 되기전이고, 돔과 같은 화면 요소에도 접근 불가
created : data 속성과 methods 속성이 정의 되었기 때문에 this.data 또는 this.fetchData()와 같은 로직들을 이용, template 속성에 정의한 돔 요소로 접근 불가. data와 methods 속성에 접근할 수 있는 가장 첫 번째 라이프 사이클 단계이므로 서버에 데이터를 요청하여 받아오는 로직을 수행하기 좋다.
beforeMount : template 속성에 지정한 마크업 속성을 render() 함수로 변환한 후 el 속성에 지정한 화면 요소에 인스턴스를 부착하기 전에 호출되는 단계
mounted : el 속성에서 지정한 화면 요소에 인스턴스가 부착되고 나면 호출되는 단계로, template 속성에 정의한 화면 요소에 접근할 수 있어 화면 요소를 제어하는 로직을 수행하기 좋은 단계입니다.
beforeUpdate : el 속성에서 지정한 화면 요소에 인스턴스가 부착되고 나면 인스턴스에 정의한 속성들이 화면에 치환. 치환된 값은 뷰의 반응성을 제공하기 위해 $watch 속성으로 감시한다.
updated : 데이터가 변경되고 나서 가상 돔으로 다시 화면을 그리고 나면 실행되는 단계. 데이터 변경으로 인한 화면 요소 변경까지 완료된 시점이므로, 데이터 변경 후 화면 요소 제어와 관련된 로직을 추가 하기 좋은 단계. 이 단계에서 데이터 값을 변경하면 무한 루프에 빠질수 있기 때문에 값을 변경하려면 computed, watch 같은 속성을 사용 해아한다.
beforeDestroy : 뷰 인스턴스가 파괴되기 직전에 호출되는 단계. 뷰 인스턴스의 데이터를 삭제하기 좋은 단계
Vue.component('컴포넌프 이름', {
//contents - ex) template: '<div>something</div>'
})
-props 속성 : 상위 컴포넌트의 데이터를 하위 컴포넌트로 넘겨줄 때 사용
<div id="app">
<child-component v-bind:propsdata="msg"></child-component>
</div>
<script>
Vue.component('child-component', {
props:['propsdata'],
template:'<p>{{propsdata}}</p>',
});
new Vue({
el: "#app",
data: {
msg : 'Hello! vue!'
}
});
</script>
//이벤트 발생
this.$emit('이벤트명');
//수신
<child-component v-on:이벤트명="상위 컴포넌트의 메서드명"></child-component>
//이벤트 버스를 위한 추가 인스턴스 1개 생성
var eventBus = new Vue();
//이벤트를 보내는 컴포넌트
methods: {
메서드명: function(){
eventBus.$emit('이벤트명',데이터);
}
}
//이벤트를 받는 컴포넌트
methods: {
created: function() {
eventBus.$on('이벤트명', function(데이터) {
//...
});
}
}