vuejs의 이벤트는 focus, Blur, click(click), dblclick, contextmen, mousemove, mouseover, mouseout, mouseup, keydown, keyup, select, 휠 등입니다.
이 튜토리얼의 운영 환경: Windows 7 시스템, vue 버전 2.9.6, DELL G3 컴퓨터.
이벤트 핸들러
이벤트 처리
Event Handler
事件处理Vuejs中的事件处理非常强大, 也非常重要。 我们一定要学好它。
Event Handler
之所以会被Vuejs放到很高的地位,是基于这样的考虑:
把跟事件相关的代码独立的写出来, 非常容易定位各种逻辑, 维护起来方便。
event handler
被独立出来之后, 页面的DOM
元素看起来就会很简单。 容易理解。当一个页面被关掉时,对应的
ViewModel
也会被回收。那么该页面定义的各种event handler
也会被一并垃圾回收。 不会造成内存溢出。
支持的Event
我们在前面曾经看到过 v-on:click
, 那么,都有哪些事件可以被v-on
所支持呢?
只要是标准的HTML定义的Event
, 都是被Vuejs支持的。
-
focus
(元素获得焦点) -
blur
(元素失去焦点) -
click
(单击 鼠标左键) -
dblclick
(双击鼠标左键) -
contextmenu
(单机鼠标右键) -
mouseover
(指针移到有事件监听的元素或者它的子元素内) -
mouseout
(指针移出元素,或者移到它的子元素上) -
keydown
(键盘动作: 按下任意键) -
keyup
(键盘动作: 释放任意键)
所有HTML标准事件:https://developer.mozilla.org/zh-CN/docs/Web/Events
例:
总共定义了 162个标准事件, 和 几十个非标准事件,以及 Mozilla的特定事件。 如下图所示:
我们不用全部都记住,通常在日常开发中,只有不到20个是最常见的event.
使用 v-on
进行事件的绑定
我们可以认为,几乎所有的事件,都是由 v-on
这个 directive
来驱动的。 所以,本节会对 v-on
有更加详尽的说明。
1. 在 v-on 中使用变量
如下面代码所示,可以在 v-on
中引用变量:
<html> <head> <script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js"></script> </head> <body> <div id='app'> 您点击了: {% raw %}{{{% endraw %} count }} 次 <br/> <button v-on:click='count += 1' style='margin-top: 50px'> + 1</button> </div> <script> var app = new Vue({ el: '#app', data: { count: 0 } }) </script> </body> </html>
上面的代码,用浏览器打开后, 点击 按钮, 就可以看到 count
这个变量会随之 +1. 如下图所示:
2. 在 v-on
中使用方法名
上面的例子,也可以按照下面的写法来实现:
<html> <head> <script ></script> </head> <body> <div id='app'> 您点击了:{% raw %}{{{% endraw %} count }} 次 <br/> <button v-on:click='increase_count' style='margin-top: 50px'> + 1 </button> </div> <script> var app = new Vue({ el: '#app', data: { count: 0 }, methods: { increase_count: function(){ this.count += 1 } } }) </script> </body> </html>
可以看到,在 v-on:click='increase_count'
中, increase_count
就是一个方法名。
3. 在v-on
中使用方法名 + 参数
我们也可以直接使用 v-on:click='some_function("your_parameter")'
这样的写法,如 下面的例子所示:
<html> <head> <script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js"></script> </head> <body> <div id='app'> {% raw %}{{{% endraw %} message }} <br/> <button v-on:click='say_hi("明日的Vuejs大神")' style='margin-top: 50px'> 跟我打个招呼~ </button> </div> <script> var app = new Vue({ el: '#app', data: { message: "这是个 在click中调用 方法 + 参数的例子" }, methods: { say_hi: function(name){ this.message = "你好啊," + name + "!" } } }) </script> </body> </html>
使用浏览器打开后,点击按钮,就可以看到下图所示:
4. 重新设计按钮的逻辑
我们在实际开发中,往往会遇到这样的情况: 点击某个按钮,或者触发某个事件后,希望按钮的默认状态。
最典型的例子: 提交表单(<form></form>
)的时候,我们希望先对该表单进行验证。 如果验证不通过,该表单就不要提交。
这个时候,如果希望表单不要提交,我们就要让 这个 submit
按钮,不要有下一步的动作。 在所有的开发语言当中,都会有一个对应的方法,叫做: “preventDefault
Vuejs의 이벤트 처리는 매우 강력하고 중요합니다. 우리는 그것을 잘 배워야 합니다.
이벤트 핸들러
Vuejs가 이를 높은 위치에 두는 이유는 다음 고려 사항에 근거합니다.
- Put Code 관련 이벤트에 대한 작성은 독립적으로 작성되므로 다양한 로직을 쉽게 찾을 수 있고 유지 관리도 쉽습니다. 🎜
- 🎜
이벤트 핸들러
가 분리되면 페이지의DOM
요소가 매우 단순해 보입니다. 이해하기 쉽습니다. 🎜 - 🎜페이지가 닫히면 해당
ViewModel
도 재활용됩니다. 그러면 페이지에 정의된 다양한이벤트 핸들러
도 가비지 수집됩니다. 메모리 오버플로가 발생하지 않습니다. 🎜
이벤트
🎜🎜us I 이전에 v-on:click
을 본 적이 있나요? 그렇다면 v-on
에서는 어떤 이벤트를 지원할 수 있나요? 🎜🎜표준 HTML로 정의된 Event
라면 Vuejs에서 지원됩니다. 🎜-
focus
(요소가 포커스를 얻음) -
blur
(요소가 포커스를 잃음) - 클릭(마우스 왼쪽 버튼 클릭)
-
dblclick
(마우스 왼쪽 버튼 두 번 클릭) 컨텍스트 메뉴
code>(독립형 마우스 오른쪽 버튼)-
mouseover
(포인터가 이벤트 리스너가 있는 요소 또는 해당 하위 요소로 이동) -
mouseout
(포인터가 요소 밖으로 또는 해당 하위 요소 위로 이동합니다) -
keydown
(키보드 동작: 아무 키나 누르십시오) - keyup code> (키보드 동작: 아무 키나 놓음)




v-on
을 사용하세요🎜 생각해보면 거의 모든 이벤트는 v-on
지시문
에 의해 구동됩니다. 따라서 이번 섹션에서는 v-on
에 대해 좀 더 자세히 설명하겠습니다. 🎜🎜1. v-on에서 변수 사용
🎜다음 코드와 같이v-on
에서 변수를 참조할 수 있습니다. 🎜<html> <head> <script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js"></script> </head> <body> <div id='app'> 请输入您想打开的网址, <br/> 判断规则是: <br/> 1. 务必以 "http://"开头 <br/> 2. 不能是空字符串 <br/> <input v-model="url" placeholder="请输入 http:// 开头的字符串, 否则不会跳转" /> <br/> <br/> <a v-bind:href="this.url" v-on:click='validate($event)'> 点我确定 </a> </div> <script> var app = new Vue({ el: '#app', data: { url: '' }, methods: { validate: function(event){ if(this.url.length == 0 || this.url.indexOf('http://') != 0){ alert("您输入的网址不符合规则。 无法跳转") if(event){ alert("event is: " + event) event.preventDefault() } } } } }) </script> </body> </html>🎜위 브라우저로 코드를 열고 버튼을 클릭하면
count
변수가 1씩 증가하는 것을 볼 수 있습니다. 아래 그림과 같이: 🎜🎜
🎜2. v-on
에서 사용됨 메소드 이름
🎜위의 예는 다음과 같이 구현할 수도 있습니다. 🎜<html> <head> <script ></script> </head> <body> <div id='app'> 请输入您想打开的网址, <br/> 判断规则是: <br/> 1. 务必以 "http://"开头 <br/> 2. 不能是空字符串 <br/> <input v-model="url" placeholder="请输入 http:// 开头的字符串, 否则不会跳转" /> <br/> <br/> <a v-bind:href="this.url" v-on:click='validate($event)' v-on:click.prevent='show_message'> 点我确定 </a> </div> <script> var app = new Vue({ el: '#app', data: { url: '' }, methods: { validate: function(event){ if(this.url.length == 0 || this.url.indexOf('http://') != 0){ if(event){ event.preventDefault() } } }, show_message: function(){ alert("您输入的网址不符合规则。 无法跳转") } } }) </script> </body> </html>🎜보시다시피
v-on:click='increase_count'
, 증가_횟수
는 메소드 이름입니다. 🎜🎜3. v-on
에서 메소드 이름 + 매개변수를 사용하세요.🎜 v-on:click='some_function( " your_parameter")'
는 다음 예와 같이 작성됩니다. 🎜<a v-bind:href="this.url" v-on:click='validate($event)' v-on:click.prevent='show_message'> 点我确定 </a> methods: { validate: function(event){ if(this.url.length == 0 || this.url.indexOf('http://') != 0){ if(event){ event.preventDefault() } } }, show_message: function(){ alert("您输入的网址不符合规则。 无法跳转") } }🎜브라우저로 연 후 버튼을 클릭하면 아래 그림을 볼 수 있습니다. 🎜

🎜4. 버튼 논리 재설계
🎜실제 개발에서는 다음과 같은 상황에 자주 직면합니다. 버튼을 클릭하거나 이벤트를 트리거한 후 버튼의 기본 상태를 원합니다. 🎜🎜가장 일반적인 예: 양식(<form></form>
)을 제출할 때 먼저 양식을 확인하려고 합니다. 확인에 실패하면 양식이 제출되지 않습니다. 🎜🎜이때 양식을 제출하지 않으려면 다음 조치 없이 이 제출
버튼을 만들어야 합니다. 모든 개발 언어에는 "preventDefault
"🎜(기본 작업 중지)🎜🎜다음 예를 살펴보겠습니다.🎜<html> <head> <script ></script> </head> <body> <div id='app'> 请输入您想打开的网址, <br/> 判断规则是: <br/> 1. 务必以 "http://"开头 <br/> 2. 不能是空字符串 <br/> <input v-model="url" placeholder="请输入 http:// 开头的字符串, 否则不会跳转" /> <br/> <br/> <a v-bind:href="this.url" v-on:click='validate($event)'> 点我确定 </a> </div> <script> var app = new Vue({ el: '#app', data: { url: '' }, methods: { validate: function(event){ if(this.url.length == 0 || this.url.indexOf('http://') != 0){ alert("您输入的网址不符合规则。 无法跳转") if(event){ alert("event is: " + event) event.preventDefault() } } } } }) </script> </body> </html>
上面的代码中,可以看到,我们定义了一个变量: url
. 并且通过代码:
<a v-bind:href="this.url" v-on:click="'validate($event)'"> 点我确定 </a>
做了两件事情:
把
url
绑定到了该元素上。该元素 在触发
click
事件时,会调用validate
方法。 该方法传递了一个特殊的参数:$event
. 该参数是当前 事件的一个实例。(MouseEvent
)
在 validate
方法中,我们是这样定义的: 先验证是否符合规则。 如果符合,放行,会继续触发 <a></a>
元素的默认动作(让浏览器发生跳转) 。 否则的
话,会弹出一个 “alert
” 提示框。
用浏览器打开这段代码,可以看到下图所示:
我们先输入一个合法的地址: http://baidu.com , 可以看到,点击后,页面发生了跳转。 跳转到了百度。
我们再输入一个 “不合法”的地址: https://baidu.com 注意: 该地址不是以 “http://” 开头,所以我们的vuejs
代码不会让它放行。
如下图所示:
进一步观察,页面也不会跳转(很好的解释了 这个时候 <a></a>
标签点了也不起作用)
5. Event Modifiers
事件修饰语
我们很多时候,希望把代码写的优雅一些。 使用传统的方式,可能会把代码写的很臃肿。 如果某个元素在不同的event
下有不同的表现,那么代码看起来就会有
很多个 if ...else ...
这样的分支。
所以, Vuejs 提供了 “Event Modifiers
”。
例如,我们可以把上面的例子略加修改:
<html> <head> <script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js"></script> </head> <body> <div id='app'> 请输入您想打开的网址, <br/> 判断规则是: <br/> 1. 务必以 "http://"开头 <br/> 2. 不能是空字符串 <br/> <input v-model="url" placeholder="请输入 http:// 开头的字符串, 否则不会跳转" /> <br/> <br/> <a v-bind:href="this.url" v-on:click='validate($event)' v-on:click.prevent='show_message'> 点我确定 </a> </div> <script> var app = new Vue({ el: '#app', data: { url: '' }, methods: { validate: function(event){ if(this.url.length == 0 || this.url.indexOf('http://') != 0){ if(event){ event.preventDefault() } } }, show_message: function(){ alert("您输入的网址不符合规则。 无法跳转") } } }) </script> </body> </html>
可以看出,上面的代码的核心是:
<a v-bind:href="this.url" v-on:click='validate($event)' v-on:click.prevent='show_message'> 点我确定 </a> methods: { validate: function(event){ if(this.url.length == 0 || this.url.indexOf('http://') != 0){ if(event){ event.preventDefault() } } }, show_message: function(){ alert("您输入的网址不符合规则。 无法跳转") } }
先是在 <a></a>
中定义了两个 click 事件,一个是 click
, 一个是 click.prevent
. 后者表示,如果该元素的click 事件被 阻止了的话, 应该触发什么动作。
然后,在 methods
代码段中,专门定义了 show_message
, 用来给 click.prevent
所使用。
上面的代码运行起来,跟前一个例子是一模一样的。 只是抽象分类的程度更高了一些。 在复杂的项目中有用处。
这样的 “event modifier”,有这些:
- stop propagation 被停止后( 也就是调用了 event.stopPropagation()方法后 ),被触发
- prevent 调用了 event.preventDefault() 后被触发。
- capture 子元素中的事件可以在该元素中 被触发。
- self 事件的 event.target 就是本元素时,被触发。
- once 该事件最多被触发一次。
- passive 为移动设备使用。 (在addEventListeners 定义时,增加passive选项。)
以上的 “event modifier” 也可以连接起来使用。 例如: v-on:click.prevent.self
6. Key Modifiers
按键修饰语
Vuejs 也很贴心的提供了 Key Modifiers, 也就是一种支持键盘事件的快捷方法。 我们看下面的例子:
<html> <head> <script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js"></script> </head> <body> <div id='app'> 输入完毕后,按下回车键,就会<br/> 触发 "show_message" 事件~ <br/><br/> <input v-on:keyup.enter="show_message" v-model="message" /> </div> <script> var app = new Vue({ el: '#app', data: { message: '' }, methods: { show_message: function(){ alert("您输入了:" + this.message) } } }) </script> </body> </html>
可以看到,在上面的代码中, v-on:keyup.enter="show_message"
为 <a></a>
元素定义了事件,该事件对应了 “回车键”。
(严格的说,是回车键被按下后,松开弹起来的那一刻)
我们用浏览器打开上面的代码对应的文件,输入一段文字,按回车,就可以看到事件已经被触发了。
Vuejs 总共支持下面这些 Key modifiers:
- enter 回车键
- tab tab 键
- delete 同时对应了 backspace 和 del 键
- esc ESC 键
- space 空格
- up 向上键
- down 向下键
- left 向左键
- right 向右键
随着 Vuejs 版本的不断迭代和更新,越来越多的 Key modifiers 被添加了进来, 例如 page down
, ctrl
。对于这些键的用法,
大家可以查阅官方文档。
相关推荐:《vue.js教程》
위 내용은 vuejs에는 어떤 이벤트가 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

React의 장점은 유연성과 효율성이며, 이는 다음과 같이 반영됩니다. 1) 구성 요소 기반 설계는 코드 재사용 성을 향상시킵니다. 2) 가상 DOM 기술은 특히 다량의 데이터 업데이트를 처리 할 때 성능을 최적화합니다. 3) 풍부한 생태계는 많은 타사 라이브러리와 도구를 제공합니다. React가 어떻게 작동하고 사용하는지 이해함으로써 핵심 개념과 모범 사례를 마스터하여 효율적이고 유지 관리 가능한 사용자 인터페이스를 구축 할 수 있습니다.

React는 크고 복잡한 응용 프로그램에 적합한 사용자 인터페이스를 구축하기위한 JavaScript 라이브러리입니다. 1. React의 핵심은 구성 요소화 및 가상 DOM으로 UI 렌더링 성능을 향상시킵니다. 2. VUE와 비교할 때 React는 더 유연하지만 가파른 학습 곡선이있어 대규모 프로젝트에 적합합니다. 3. Angular와 비교하여 React는 더 가볍고 지역 사회 생태에 의존하며 유연성이 필요한 프로젝트에 적합합니다.

React는 Virtual Dom을 통해 HTML에서 작동합니다. 1) REACT는 JSX 구문을 사용하여 HTML 유사 구조를 작성합니다. 2) 가상 DOM 관리 UI 업데이트, 확산 알고리즘을 통한 효율적인 렌더링. 3) reftdom.render ()를 사용하여 구성 요소를 실제 DOM으로 렌더링하십시오. 4) 최적화 및 모범 사례에는 성능 및 유지 관리 가능성을 향상시키기 위해 React.Memo 및 구성 요소 분할 사용이 포함됩니다.

React는 전자 상거래, 소셜 미디어 및 데이터 시각화에 널리 사용됩니다. 1) 전자 상거래 플랫폼은 React를 사용하여 쇼핑 카트 구성 요소를 구축하고, usestate를 사용하여 상태를 관리하고, 이벤트를 처리하기 위해 ONCLICK 및 MAP 기능을 렌더링합니다. 2) 소셜 미디어 응용 프로그램은 사용률을 통해 API와 상호 작용하여 동적 컨텐츠를 표시합니다. 3) 데이터 시각화는 React-Chartjs-2 라이브러리를 사용하여 차트 렌더링을 사용하며 구성 요소 설계는 응용 프로그램을 쉽게 포함시킬 수 있습니다.

React 프론트 엔드 아키텍처를위한 모범 사례에는 다음이 포함됩니다. 1. 구성 요소 설계 및 재사용 : 단일 책임, 이해하기 쉬운 및 테스트 구성 요소를 설계하여 높은 재사용을 달성합니다. 2. State Management : usestate, usestate, usereducer, contextapi 또는 redux/mobx를 사용하여 상태를 관리하여 과도한 복잡성을 피하십시오. 3. 성능 최적화 : react.memo, Usecallback, Usememo 및 기타 방법을 통해 성능을 최적화하여 밸런스 포인트를 찾습니다. 4. 코드 조직 및 모듈성 : 기능 모듈에 따라 코드를 구성하여 관리 가능성과 유지 관리를 향상시킵니다. 5. 테스트 및 품질 보증 : 코드의 품질과 신뢰성을 보장하기 위해 Jest 및 ReactTestingLibrary로 테스트

반응을 HTML에 통합하려면 다음 단계를 따르십시오. 1. HTML 파일에 React 및 Reactdom을 소개하십시오. 2. 반응 구성 요소를 정의합니다. 3. 반응을 사용하여 구성 요소를 HTML 요소로 렌더링합니다. 이러한 단계를 통해 정적 HTML 페이지를 역동적이고 대화식 경험으로 변환 할 수 있습니다.

React의 인기에는 성능 최적화, 구성 요소 재사용 및 풍부한 생태계가 포함됩니다. 1. 성능 최적화는 가상 DOM 및 Diffing 메커니즘을 통해 효율적인 업데이트를 달성합니다. 2. 구성 요소 재사용은 재사용 가능한 구성 요소에 의해 중복 코드를 줄입니다. 3. 풍부한 생태계와 일원 데이터 흐름은 개발 경험을 향상시킵니다.

React는 동적 및 대화식 사용자 인터페이스를 구축하기위한 선택 도구입니다. 1) 구성 요소화 및 JSX는 UI 분할 및 재사용을 간단하게 만듭니다. 2) State Management는 Usestate 후크를 통해 구현되어 UI 업데이트를 트리거합니다. 3) 이벤트 처리 메커니즘은 사용자 상호 작용에 응답하고 사용자 경험을 향상시킵니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.
