VueJS-이벤트

v-on VueJS에서 이벤트를 수신하기 위해 DOM 요소에 추가 된 속성입니다.

클릭 이벤트

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "databinding">
         <button v-on:click = "displaynumbers">Click ME</button>
         <h2> Add Number 100 + 200 = {{total}}</h2>
      </div>
      <script type = "text/javascript">
         var vm = new Vue({
            el: '#databinding',
            data: {
               num1: 100,
               num2 : 200,
               total : ''
            },
            methods : {
               displaynumbers : function(event) {
                  console.log(event);
                  return this.total =  this.num1+ this.num2;
               }
            },
         });
      </script>
   </body>
</html>

산출

다음 코드는 DOM 요소에 대한 클릭 이벤트를 할당하는 데 사용됩니다.

<button v-on:click = "displaynumbers">Click ME</button>

v-on의 약어가 있습니다. 즉, 다음과 같이 이벤트를 호출 할 수도 있습니다.

<button @click = "displaynumbers">Click ME</button>

버튼을 클릭하면 이벤트를받는 'displaynumbers'메소드가 호출되며, 위와 같이 브라우저에서 동일하게 콘솔 처리했습니다.

이제 이벤트 mouseover mouseout을 하나 더 확인합니다.

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "databinding">
         <div v-bind:style = "styleobj" v-on:mouseover = "changebgcolor" v-on:mouseout = "originalcolor"></div>
      </div>
      <script type = "text/javascript">
         var vm = new Vue({
            el: '#databinding',
            data: {
               num1: 100,
               num2 : 200,
               total : '',
               styleobj : {
                  width:"100px",
                  height:"100px",
                  backgroundColor:"red"
               }
            },
            methods : {
               changebgcolor : function() {
                  this.styleobj.backgroundColor = "green";
               },
               originalcolor : function() {
                  this.styleobj.backgroundColor = "red";
               }
            },
         });
      </script>
   </body>
</html>

위의 예에서는 너비와 높이가 100px 인 div를 만들었습니다. 배경색이 빨간색으로 지정되었습니다. 마우스 오버시 색상을 녹색으로 변경하고 마우스 아웃시 색상을 다시 빨간색으로 변경합니다.

따라서 마우스 오버 중에 메서드가 호출됩니다. changebgcolor 마우스를 div 밖으로 이동하면 메서드가 호출됩니다. originalcolor.

이것은 다음과 같이 수행됩니다-

<div v-bind:style = "styleobj" v-on:mouseover = "changebgcolor" v-on:mouseout = "originalcolor"></div>

위에 표시된 것처럼 두 개의 이벤트 (mouseover 및 mouseout)가 div에 할당됩니다. styleobj 변수를 만들고 div에 할당 할 필수 스타일을 지정했습니다. v-bind : style =”styleobj”를 사용하여 동일한 변수가 div에 바인딩됩니다.

changebgcolor에서는 다음 코드를 사용하여 색상을 녹색으로 변경합니다.

changebgcolor : function() {
   this.styleobj.backgroundColor = "green";
}

stylobj 변수를 사용하여 색상을 녹색으로 변경합니다.

마찬가지로 다음 코드를 사용하여 원래 색상으로 다시 변경합니다.

originalcolor : function() {
   this.styleobj.backgroundColor = "red";
}

이것이 우리가 브라우저에서 보는 것입니다.

마우스를 가져 가면 다음 스크린 샷과 같이 색상이 녹색으로 바뀝니다.

이벤트 수정 자

Vue에는 v-on 속성에서 사용할 수있는 이벤트 수정자가 있습니다. 다음은 사용 가능한 수정 자입니다-

.한번

이벤트가 한 번만 실행되도록합니다.

통사론

<button v-on:click.once = "buttonclicked">Click Once</button>

위 구문과 같이 수정자를 호출하는 동안 점 연산자를 추가해야합니다. 예제에서 사용하고 한 번 수정 자의 작동을 이해하겠습니다.

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "databinding">
         <button v-on:click.once = "buttonclickedonce" v-bind:style = "styleobj">Click Once</button>
         Output:{{clicknum}}
         <br/><br/>
         <button v-on:click = "buttonclicked"  v-bind:style = "styleobj">Click Me</button>
         Output:{{clicknum1}}
      </div>
      <script type = "text/javascript">
         var vm = new Vue({
            el: '#databinding',
            data: {
               clicknum : 0,
               clicknum1 :0,
               styleobj: {
                  backgroundColor: '#2196F3!important',
                  cursor: 'pointer',
                  padding: '8px 16px',
                  verticalAlign: 'middle',
               }
            },
            methods : {
               buttonclickedonce : function() {
                  this.clicknum++;
               },
               buttonclicked : function() {
                  this.clicknum1++;
               }
            }
         });
      </script>
   </body>
</html>

산출

위의 예에서는 두 개의 버트 톤을 만들었습니다. 한 번 클릭 레이블이있는 버튼은 한 번 수정자를 추가하고 다른 버튼에는 수정자가 없습니다. 이것이 버튼이 정의되는 방식입니다.

<button v-on:click.once = "buttonclickedonce" v-bind:style = "styleobj">Click Once</button>
<button v-on:click = "buttonclicked"  v-bind:style = "styleobj">Click Me</button>

첫 번째 버튼은 "buttonclickedonce"메서드를 호출하고 두 번째 버튼은 "buttonclicked"메서드를 호출합니다.

buttonclickedonce : function() {
   this.clicknum++;
},
buttonclicked : function() {
   this.clicknum1++;
}

clicknum 및 clicknum1에는 두 개의 변수가 정의되어 있습니다. 버튼을 클릭하면 둘 다 증가합니다. 두 변수는 모두 0으로 초기화되고 디스플레이는 위의 출력에 표시됩니다.

첫 번째 버튼을 클릭하면 변수 clicknum이 1 씩 증가합니다. 두 번째 클릭에서는 수정자가 버튼 클릭시 할당 된 작업 항목을 실행하거나 수행하지 못하도록 차단하므로 숫자가 증가하지 않습니다.

두 번째 버튼을 클릭하면 동일한 작업이 수행됩니다. 즉, 변수가 증가합니다. 클릭 할 때마다 값이 증가하고 표시됩니다.

다음은 브라우저에서 얻은 출력입니다.

.막다

Syntax

<a href = "http://www.google.com" v-on:click.prevent = "clickme">Click Me</a>

Example

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "databinding">
         <a href = "http://www.google.com" v-on:click = "clickme" target = "_blank" v-bind:style = "styleobj">Click Me</a>
      </div>
      <script type = "text/javascript">
         var vm = new Vue({
            el: '#databinding',
            data: {
               clicknum : 0,
               clicknum1 :0,
               styleobj: {
                  color: '#4CAF50',
                  marginLeft: '20px',
                  fontSize: '30px'
               }
            },
            methods : {
               clickme : function() {
                  alert("Anchor tag is clicked");
               }
            }
         });
      </script>
   </body>
</html>

Output

clickme 링크를 클릭하면 "Anchor tag is clicked"라는 알림이 전송되고 링크가 열립니다. https://www.google.com 다음 스크린 샷에 표시된대로 새 탭에서.

이제 이것은 정상적인 방식으로 작동합니다. 즉, 링크가 원하는대로 열립니다. 링크를 열지 않으려면 다음 코드와 같이 이벤트에 '예방'수정자를 추가해야합니다.

<a href = "http://www.google.com" v-on:click.prevent = "clickme" target = "_blank" v-bind:style = "styleobj">Click Me</a>

추가 된 후 버튼을 클릭하면 경고 메시지가 전송되고 링크가 더 이상 열리지 않습니다. prevent 수정자는 링크가 열리지 않도록하고 태그에 할당 된 메서드 만 실행합니다.

Example

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "databinding">
         <a href = "http://www.google.com" v-on:click.prevent = "clickme" target = "_blank" v-bind:style = "styleobj">Click Me</a>
      </div>
      <script type = "text/javascript">
         var vm = new Vue({
            el: '#databinding',
            data: {
               clicknum : 0,
               clicknum1 :0,
               styleobj: {
                  color: '#4CAF50',
                  marginLeft: '20px',
                  fontSize: '30px'
               }
            },
            methods : {
               clickme : function() {
                  alert("Anchor tag is clicked");
               }
            }
         });
      </script>
   </body>
</html>

Output

링크를 클릭하면 경고 메시지가 표시되고 URL이 더 이상 열리지 않습니다.

이벤트-키 수정 자

VueJS는 이벤트 처리를 제어 할 수있는 키 수정자를 제공합니다. 텍스트 상자가 있고 Enter 키를 누를 때만 메서드가 호출되기를 원합니다. 다음과 같이 이벤트에 키 수정자를 추가하여이를 수행 할 수 있습니다.

통사론

<input type = "text"  v-on:keyup.enter = "showinputvalue"/>

이벤트에 적용하고 싶은 핵심은 V-on.eventname.keyname (위와 같이)

여러 키 이름을 사용할 수 있습니다. 예를 들면V-on.keyup.ctrl.enter

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "databinding">
         <input type = "text" v-on:keyup.enter = "showinputvalue" v-bind:style = "styleobj" placeholder = "Enter your name"/>
         <h3> {{name}}</h3>
      </div>
      <script type = "text/javascript">
         var vm = new Vue({
            el: '#databinding',
            data: {
               name:'',
               styleobj: {
                  width: "30%",
                  padding: "12px 20px",
                  margin: "8px 0",
                  boxSizing: "border-box"
               }
            },
            methods : {
               showinputvalue : function(event) {
                  this.name=event.target.value;
               }
            }
         });
      </script>
   </body>
</html>

산출

텍스트 상자에 내용을 입력하면 Enter 키를 누를 때만 표시됩니다.

맞춤 이벤트

부모는 prop 속성을 사용하여 해당 구성 요소에 데이터를 전달할 수 있지만 자식 구성 요소에 변경 사항이있을 때 부모에게 알려야합니다. 이를 위해 사용자 지정 이벤트를 사용할 수 있습니다.

부모 구성 요소는 다음을 사용하여 자식 구성 요소 이벤트를 수신 할 수 있습니다. v-on 속성.

<html>
   <head>
      <title>VueJs Instance</title>
      <script type = "text/javascript" src = "js/vue.js"></script>
   </head>
   <body>
      <div id = "databinding">
         <div id = "counter-event-example">
            <p style = "font-size:25px;">Language displayed : <b>{{ languageclicked }}</b></p>
            <button-counter
            v-for = "(item, index) in languages"
            v-bind:item = "item"
            v-bind:index = "index"
            v-on:showlanguage = "languagedisp"></button-counter>
         </div>
      </div>
      <script type = "text/javascript">
         Vue.component('button-counter', {
            template: '<button v-on:click = "displayLanguage(item)"><span style = "font-size:25px;">{{ item }}</span></button>',
            data: function () {
               return {
                  counter: 0
               }
            },
            props:['item'],
            methods: {
               displayLanguage: function (lng) {
                  console.log(lng);
                  this.$emit('showlanguage', lng);
               }
            },
         });
         var vm = new Vue({
            el: '#databinding',
            data: {
               languageclicked: "",
               languages : ["Java", "PHP", "C++", "C", "Javascript", "C#", "Python", "HTML"]
            },
            methods: {
               languagedisp: function (a) {
                  this.languageclicked = a;
               }
            }
         })
      </script>
   </body>
</html>

산출

위의 코드는 상위 구성 요소와 하위 구성 요소 간의 데이터 전송을 보여줍니다.

구성 요소는 다음 코드를 사용하여 생성됩니다.

<button-counter
   v-for = "(item, index) in languages"
   v-bind:item = "item"
   v-bind:index = "index"
   v-on:showlanguage = "languagedisp">
</button-counter>

이있다 v-for언어 배열과 함께 반복되는 속성입니다. 배열에는 언어 목록이 있습니다. 세부 정보를 하위 구성 요소로 보내야합니다. 배열의 값은 항목과 인덱스에 저장됩니다.

v-bind:item = "item"
v-bind:index = "index"

배열의 값을 참조하려면 먼저 변수에 바인딩해야하며 다음과 같이 props 속성을 사용하여 varaiable을 참조합니다.

Vue.component('button-counter', {
   template: '<button v-on:click = "displayLanguage(item)"><span style = "font-size:25px;">{{ item }}</span></button>',
   data: function () {
      return {
         counter: 0
      }
   },
   props:['item'],
   methods: {
      displayLanguage: function (lng) {
         console.log(lng);
         this.$emit('showlanguage', lng);
      }
   },
});

props 속성은 배열 형식의 항목을 포함합니다. 인덱스를 다음과 같이 참조 할 수도 있습니다.

props:[‘item’, ‘index’]

다음과 같이 구성 요소에 추가 된 이벤트도 있습니다-

<button-counter
   v-for = "(item, index) in languages"
   v-bind:item = "item"
   v-bind:index = "index"
   v-on:showlanguage = "languagedisp">
</button-counter>

이벤트 이름은 showlanguage 호출 된 메서드를 호출합니다. languagedisp Vue 인스턴스에 정의되어 있습니다.

컴포넌트에서 템플릿은 다음과 같이 정의됩니다.

template: '<button v-on:click = "displayLanguage(item)"><span style = "font-size:25px;">{{ item }}</span></button>',

생성 된 버튼이 있습니다. 버튼은 언어 배열의 개수만큼 생성됩니다. 버튼을 클릭하면 displayLanguage라는 메소드가 있으며 버튼을 클릭 한 항목은 함수에 매개 변수로 전달됩니다. 이제 컴포넌트는 다음과 같이 수행되는 표시를 위해 클릭 된 요소를 상위 컴포넌트로 보내야합니다.

Vue.component('button-counter', {
   template: '<button v-on:click = "displayLanguage(item)"><span style = "font-size:25px;">{{ item }}</span></button>',
   data: function () {
      return {
         counter: 0
      }
   },
   props:['item'],
   methods: {
      displayLanguage: function (lng) {
         console.log(lng);
         this.$emit('showlanguage', lng);
      }
   },
});

방법 displayLanguage 전화 this.$emit(‘showlanguage’, lng);

$emit부모 구성 요소 메서드를 호출하는 데 사용됩니다. showlanguage 메소드는 v-on을 사용하여 구성 요소에 지정된 이벤트 이름입니다.

<button-counter
   v-for = "(item, index) in languages"
   v-bind:item = "item"
   v-bind:index = "index"
   v-on:showlanguage = "languagedisp">
</button-counter>

우리는 매개 변수, 즉 클릭 된 언어의 이름을 다음과 같이 정의 된 메인 부모 Vue 인스턴스의 메소드에 전달합니다.

var vm = new Vue({
   el: '#databinding',
   data: {
      languageclicked: "",
      languages : ["Java", "PHP", "C++", "C", "Javascript", "C#", "Python", "HTML"]
   },
   methods: {
      languagedisp: function (a) {
         this.languageclicked = a;
      }
   }
})

여기에서 emit는 showlanguage를 트리거합니다. languagedispVue 인스턴스 메서드에서. 클릭 한 언어 값을 변수에 할당합니다.languageclicked 다음 스크린 샷과 같이 브라우저에 동일한 내용이 표시됩니다.

<p style = "font-size:25px;">Language displayed : <b>{{ languageclicked }}</b></p>

다음은 브라우저에서 얻은 출력입니다.