data:image/s3,"s3://crabby-images/7355d/7355dbf9d661db2c86066e4eedb151f7723f6292" alt="Vue.js의 Method와 Event"
- 증가 버튼 만들기
<!--HTML 코드 작성--> <template> <h1>{{ count }}</h1> <button>증가</button> </template> <!--Java Script 코드 작성--> <script> export default { name: 'App', // 컴포넌트의 이름 data() { return { count: 0 } }, methods: { } }; </script>
data:image/s3,"s3://crabby-images/a1f42/a1f42905f8e9587925b94d9af9e6a18053894ca3" alt="notion image"
- v-on = @
- 클릭 이벤트 확인
- 이벤트 핸들러를 요소에 연결할 때 사용하는 디렉티브
- 사용자 인터페이스에서 발생하는 이벤트(클릭, 입력 등)에 반응하여 특정 동작을 수행할 때 사용
<!--HTML 코드 작성--> <template> <h1>{{ count + 1 }}</h1> <button v-on:click="addNumber">증가</button> <!--클릭 이벤트로 메서드 실행--> </template> <!--Java Script 코드 작성--> <script> export default { name: 'App', data() { return { count: 0 } }, methods: { addNumber() { console.log("addNumber가 실행되었습니다") } } }; </script>
data:image/s3,"s3://crabby-images/14a81/14a8124db78677399d28d286f75181ed575dbb32" alt="notion image"
- 값에 접근하기 위해 this라는 키워드가 필요함
<!--HTML 코드 작성--> <template> <h1>{{ count + 1 }}</h1> <button v-on:click="addNumber">증가</button> <!--클릭 이벤트로 메서드 실행--> </template> <!--Java Script 코드 작성--> <script> export default { name: 'App', data() { return { count: 0 } }, methods: { addNumber() { this.count = this.count +1; // 값에 접근하기 위해 this라는 키워드가 필요함 } } }; </script>
data:image/s3,"s3://crabby-images/adf1f/adf1f5f9e95589fa1769742373e3e3c8e36a2e4d" alt="notion image"
data:image/s3,"s3://crabby-images/6dcd3/6dcd34ddaf77ed963cc1f67adbe395d0d7e3f9c8" alt="notion image"
- 감소 버튼 만들기
- Arrow Function(화살표 함수)를 사용하면 this키워드가 올바르게 동작하지 않을 수 있음
- 자신의 this 컨텍스트를 가지지 않고, 부모 스코프의 this를 그대로 사용하기 때문
<!--HTML 코드 작성--> <template> <h1>{{ count + 1 }}</h1> <button v-on:click="addNumber">증가</button> <!--클릭 이벤트로 메서드 실행--> <button v-on:click="minusNumber">감소</button> <!--클릭 이벤트로 메서드 실행--> </template> <!--Java Script 코드 작성--> <script> export default { name: 'App', data() { return { count: 0 } }, methods: { addNumber() { this.count = this.count + 1; // 값에 접근하기 위해 this라는 키워드가 필요함 }, minusNumber() { this.count = this.count - 1; } } }; </script>
data:image/s3,"s3://crabby-images/8ad4e/8ad4edec6c5ac68b5115d69d7302801d57cd8580" alt="notion image"
data:image/s3,"s3://crabby-images/b5901/b5901f5cc44eafd003e4a69fdc4082c52c62b564" alt="notion image"
- 숫자를 받아서 그 숫자만큼 증가시키기
<!--HTML 코드 작성--> <template> <h1>{{ count + 1 }}</h1> <button v-on:click="addNumber">증가</button> <!--클릭 이벤트로 메서드 실행--> <button v-on:click="minusNumber">감소</button> <button v-on:click="addNumber(10)">10씩 증가</button> </template> <!--Java Script 코드 작성--> <script> export default { name: 'App', data() { return { count: 0 } }, methods: { addNumber(value) { this.count = this.count + value; }, minusNumber() { this.count = this.count - 1; }, } }; </script>
data:image/s3,"s3://crabby-images/91176/9117627238d1661520777ea5f3a9819d0cc00a40" alt="notion image"
data:image/s3,"s3://crabby-images/95cf2/95cf26f99ef71448edfa8acd22a2da6d30fc8cff" alt="notion image"
- 마우스오버 이벤트로 변경
<template> <h1>{{ count + 1 }}</h1> <button v-on:click="addNumber">증가</button> <!--클릭 이벤트로 메서드 실행--> <button v-on:click="minusNumber">감소</button> <button v-on:mouseover="addNumber(10)">마우스 오버 10씩 증가</button> </template>
data:image/s3,"s3://crabby-images/7b8cc/7b8cc92637e891ef1cc8824c7b5313b78c32724d" alt="notion image"
data:image/s3,"s3://crabby-images/55a80/55a8054af7bc056445c1a92903142e97ac8cf965" alt="notion image"
- 값을 전달해주지 않으면 기본적으로 이벤트 객체가 들어가게 됨
data:image/s3,"s3://crabby-images/306b9/306b9a88884e9465ed17a7d3beb2194d37fa646a" alt="notion image"
<script> export default { name: 'App', data() { return { count: 0 } }, methods: { addNumber(value) { console.log(value); this.count = this.count + value; }, minusNumber() { this.count = this.count - 1; }, } }; </script>
data:image/s3,"s3://crabby-images/7101f/7101fcada8eeb4197eaa08b2cdc29a0e57e8af54" alt="notion image"
- value 값 전달하기
<template> <h1>{{ count + 1 }}</h1> <button v-on:click="addNumber(1)">증가</button> <!--클릭 이벤트로 메서드 실행--> <button v-on:click="minusNumber">감소</button> <button v-on:mouseover="addNumber(10)">마우스 오버 10씩 증가</button> </template>
data:image/s3,"s3://crabby-images/6377d/6377d8ef6f0fafa2fc8720f7c38743b13a7cb904" alt="notion image"
- v-on을 @로 축약해서 사용하기
<!--HTML 코드 작성--> <template> <h2>{{ message }}</h2> <button @click="greeting">인사하기</button> <button @click="goodBye">작별하기</button> </template> <!--Java Script 코드 작성--> <script> export default { name: 'App', data() { return { count: 0, message: "" } }, methods: { greeting() { this.message = "안녕하세요" }, goodBye(){ this.message = "안녕히가세요" }, } }; </script
data:image/s3,"s3://crabby-images/d3e3c/d3e3cfd49b08ff9df9e31dc41b5b780581427bcc" alt="notion image"
data:image/s3,"s3://crabby-images/bdcd2/bdcd297f3d4c0d1935bc472110d9f0de6c23f2d9" alt="notion image"
- 어떠한 값도 넘기지 않으면 이벤트 값을 받을 수 있음
<!--HTML 코드 작성--> <template> <h2>{{ message }}</h2> <div @mouseover="getMousePosition" class="box"></div> </template> <!--Java Script 코드 작성--> <script> export default { name: 'App', data() { return { count: 0, message: "" } }, methods: { getMousePosition(event) { console.log(event); this.message = "마우스의 값" }, } }; </script>
data:image/s3,"s3://crabby-images/41003/41003a6554d7b957574d72e30f3f9f30f41fc787" alt="notion image"
<script> export default { name: 'App', data() { return { count: 0, message: "" } }, methods: { getMousePosition(event) { console.log(event); this.message = `마우스는 ${event.pageX}와 ${event.pageY}에 있습니다`; }, } }; </script>
data:image/s3,"s3://crabby-images/490b9/490b9b5d82d7012a974960443d33d999be283a7d" alt="notion image"
- e.pageX를 사용하려면 e라는 이름의 이벤트 객체를 함수에 인자로 전달 안하면 오류 남
<!--HTML 코드 작성--> <template> <h2>{{ message }}</h2> <button @click="addNumber(10)">10씩 증가</button> <button @click="addNumber(100)">100씩 증가</button> </template> <!--Java Script 코드 작성--> <script> export default { name: 'App', data() { return { message: "" } }, methods: { getMousePosition(event) { console.log(event); this.message = `마우스는 ${event.pageX}와 ${event.pageY}에 있습니다`; }, addNumber(value) { e.pageX console.log(value); this.message= `마우스 좌표 ${e.pageX}와 더하기 ${value}는 ${e.pageX + value}`; }, } }; </script>
data:image/s3,"s3://crabby-images/6ae10/6ae10413c0bde09615a36c3e8801c918cbee9ea7" alt="notion image"
- 현재 VIEW에서 사용하는 이벤트가 파라미터로 명시할 수 있음
<!--HTML 코드 작성--> <template> <h2>{{ message }}</h2> <button @click="addNumber($event, 10)">10씩 증가</button> <button @click="addNumber($event, 100)">100씩 증가</button> </template> <!--Java Script 코드 작성--> <script> export default { name: 'App', data() { return { message: "" } }, methods: { getMousePosition(event) { console.log(event); this.message = `마우스는 ${event.pageX}와 ${event.pageY}에 있습니다`; }, addNumber(e, value) { e.pageX console.log(value); this.message = `마우스 좌표 ${e.pageX}와 더하기 ${value}는 ${e.pageX + value}`; }, } }; </script>
data:image/s3,"s3://crabby-images/1a9bd/1a9bd8c7a083d5f6a7470a066eaa872326373c55" alt="notion image"
data:image/s3,"s3://crabby-images/ea165/ea1655db7e91f4195ed6d7137cf9da14b931dcd5" alt="notion image"
Share article