专业编程基础技术教程

网站首页 > 基础教程 正文

vue-07 事件处理 v-on(vue 事件原理)

ccvgpt 2024-08-02 11:54:13 基础教程 16 ℃

事件处理方法

  • 完整格式: v-on:事件名="函数名" 或 v-on:事件名="函数名(参数……)"
  • 缩写格式: @事件名="函数名" 或 @事件名="函数名(参数……)" 注意: @ 后面没有冒号
  • event :函数中的默认形参,代表原生 DOM 事件

当调用的函数,有多个参数传入时,需要使用原生DOM事件,则通过 $event 作为实参传入

  • 作用:用于监听 DOM 事件

事件修饰符

  • .stop 阻止单击事件继续传播 event.stopPropagation()
  • .prevent 阻止事件默认行为 event.preventDefault()
  • .once 点击事件将只会触发一次

按键修饰符

  • 格式: v-on:keyup.按键名 或 @keyup.按键名
  • 常用按键名:

.enter

vue-07 事件处理 v-on(vue 事件原理)

.tab

.delete (捕获“删除”和“退格”键)

.esc

.space


.up

.down

.left

.right

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="app">
        <h3>1、事件处理方法 v-on或@</h3>
        <button v-on:click="say">Say {{msg}}</button>
        <!-- $event代表的是原生Dom事件 -->
        <button @click="warn('hello',$event)">Warn</button>

        <h3>2、事件修饰符</h3>
        <!-- 2.1防止单击事件继续传播 -->
        <div @click="toDo">
            <button @click="doThis">单击事件会继续传播</button>
        </div><br/>
        <div @click="toDo">
            <button @click.stop="doThis">阻止事件会继续传播</button>
        </div><br/>

        <!-- 2.2阻止事件的默认行为 -->
        <a href="www.baidu.com" @click.prevent="doStop">百度一下</a>

        <!-- 2.3点击事件只会触发一次 -->
        <button @click.once="doOnly">Only once:{{num}}</button>

        <h3>3、按键修饰符</h3>
        <input @keyup.enter="keyEnter">
        <input @keyup.space="keySpace">
        <input @keyup.13="keyCode">
    </div>
    <script src="./node_modules/vue/dist/vue.js"></script>
    <script>
        var vm = new Vue({
            el: '#app',
            data: {
                msg: 'Hello Cyz!',
                num : 0
            },
            methods: {
                say: function(event){
                    alert(this.msg)
                    alert(event.target.innerHTML)
                },
                // 如果说函数有多个参数,而又需要用原生事件,则需要使用$event作为参数传入
                warn: function(msg,event){
                    alert(msg + ',' + event.target.tagName)
                },
                doThis: function(){
                    alert('doThis...')
                },
                toDo: function(){
                    alert('toDo...')
                },
                doStop: function(){
                    alert("doStop...")
                },
                doOnly: function(){
                    this.num ++
                },
                keyEnter: function(){
                    alert('按键为确认键')
                },
                keySpace: function(){
                    alert('按键为空格键')
                },
                keyCode: function(){
                    alert('按键为确认键')
                }
            },
        })
    </script>
</body>
</html>

Tags:

最近发表
标签列表