Study/Vue.js
[Vue.js] 07 SFC(Single File Component)
록씨
2021. 9. 24. 09:25
반응형
Single File Component
- 화면의 특정 영역에 대한 HTML, CSS, JS 코드를 한 파일에서 관리하는 방법
- 전역 컴포넌트는 Vue.component를 사용해 정의되고, container 엘리먼트를 대상으로 하는 new Vue({el: '#container'})가 정의됐었다.
- vue 확장자를 가진 파일을 모두 싱글 파일 컴포넌트라고 한다.
- 뷰 로더에 의해 HTML, CSS, JS와 같은 웹 자원으로 분리되어 실행
- 프론트엔드가 Javascript 기반인 경우 단점
- 전역 정의 모든 구성 요소에 대해 고유한 이름을 지정하도록 강요.
- 구문 강조가 약해 여러 줄로 된 HTML에 보기 안좋은 슬래시가 많이 필요
.Vue 확장자
- 완전한 구문 강조
- CommonJS 모듈
- 컴포넌트에만 제한된 CSS
- 각 *.vue 파일은 한번에 최대 하나의 template, script 블록과 여러개의 style 블록을 포함할 수 있다.
- 관심사 분리
- 현대적인 UI 개발에서 코드베이스를 서로 얽혀있는 세 개의 거대한 레이어로 나누는 대신, 느슨하게 결합 된 컴포넌트로 나누고 구성하는 것이 더 중요하다.
- 템플릿, 로직 및 스타일이 본질적으로 결합되어 배치되면 컴포넌트의 응집력과 유지 보수성이 향상된다
//Test.vue
<template>
</template>
<script>
export default {
name: "Test"
}
</script>
<style scoped> // scoped or module
</style>
이벤트
- 등록
- 버블링
- 캡쳐
- 전파 방지
이벤트 등록
<button>add one item</button>
var button = document.querySelector('button');
button.addEventListener('click', addItem);
function addItem(event) {
console.log(event);
}
이벤트 버블링
- 특정 화면 요소에서 이벤트가 발생했을 때 해당 이벤트가 더 상위의 화면 요소들로 전달되어 가는 특성
- 브라우저는 특정 화면 요소에서 이벤트가 발생했을 때 그 이벤트를 최상위에 있는 화면 요소까지 이벤트를 전파
<body>
<div class="one">
<div class="two">
<div class="three">
</div>
</div>
</div>
</body>
var divs = document.querySelectorAll('div');
divs.forEach(function(div) {
div.addEventListener('click', logEvent);
});
function logEvent(event) {
console.log(event.currentTarget.className);
}
이벤트 캡쳐
- 이벤트 버블링과 반대 방향으로 진행되는 이벤트 전파 방식.
- 이벤트가 발생했을 때 최상위 요소인 body 태그에서 해당 태그를 찾아 내려간다.
var divs = document.querySelectorAll('div');
divs.forEach(function(div) {
div.addEventListener('click', logEvent, {
capture: true // default 값은 false입니다.
});
});
function logEvent(event) {
console.log(event.currentTarget.className);
}
전파 방지
//javascript
function logEvent(event) {
event.stopPropagation();
}
// vue(수식어사용)
<a v-on:click.stop="doThis"></a>
preventDefault() 와의 차이
- e.preventDefault는 고유 동작을 중단시키고, e.stopPropagation 는 상위 엘리먼트들로의 이벤트 전파를 중단시킨다.
<a href="https://www.naver.com">Naver</a>
$("a").click(function(e){
e.preventDefault();
alert("e.preventDefault()");
});
반응형