[vue.js] Minin 사용방법 (event)

tobo·2022년 6월 2일
0

Vue.js

목록 보기
2/7
post-thumbnail
post-custom-banner

Mixins는 Vue 컴포넌트에 재사용 가능한 기능을 배포하는 유연한 방법입니다. mixin 객체는 모든 구성 요소 옵션을 포함할 수 있습니다. 컴포넌트에 mixin을 사용하면 해당 mixin의 모든 옵션이 컴포넌트의 고유 옵션에 “혼합”됩니다.
- vue 공식문서


  1. 버튼을 클릭하면 count가 1씩 증가하는 method를 만들어보자.
// ComponentA.vue
<template>
	<button @click="incrementCount">Clicked {{ count }} times</button>
</template>

<script>
	export default {
    	name: 'component-a',
		data() {
    		return { count: 0 }
    	},
  		methods: {
    		incrementCount() {
        		this.count += 1
       		}
    	},
    }
</script>
  1. incrementCount()의 재사용성을 위해 별도의 믹스인 파일 counterMixin.js 을 만들어 보자.
// counterMixin.js
const counterMixin = {
	data() {
    	return { count: 0 }
    },
  	methods: {
    	incrementCount() {
        	this.count += 1
        }
    }
}

export default counterMixin;

  1. 두개의 파일을 연결하면 아래와 같다.
// ComponentA.vue
<template>
	<button @click="incrementCount">Clicked {{ count }} times</button>
</template>

<script>
    import counterMixin from './counterMixin'

	export default {
    	name: 'component-a',
      	mixins: [counterMixin],
    }
</script>

재사용성 예시
버튼에 @click @mouseover @mouseout 등 각종 이벤트에 incrementCount()(1씩 증가하는 함수)를 적용할 수 있다.


*이벤트명 참고
아래의 이벤트명을 v-on: 또는 @와 같이 사용하면 된다.

EventDescription
click마우스를 클릭했을 때 실행
dbclick마우스를 더블 클릭했을 때 실행
mouseover마우스 포인터가 요소 위로 올라왔을때 실행
mouseout마우스 포인터가 요소 밖으로 벗어났을때 실행
mousedown마우스의 버튼을 눌렀을 때 실행
mouseup마우스 버튼을 놓았을 때 실행
keydown키보드의 키를 눌렀을때 실행
keyup키보드의 키를 놓았을 때 실행
keypress키보드의 키를 눌렀다가 놓았을 때 실행
change요소가 변경될 때 실행
submit<form>이 제출될 때 실행
reset<form>이 재설정될 때 실행
select<select>의 값이 선택되었을 때 실행
focus태그에 포커스가 있을 때 실행
profile
"Think Now, Design Later"
post-custom-banner

0개의 댓글