Vue_事件处理

一,事件的基本使用:

            1,使用v-on:xxx 或者 @xxx 绑定事件,其中xxx是事件名。如:v-on:click/@click

            2,事件的回调需要配置在methods对象中,最终会在vm上

            3,methods中配置的函数,不要用箭头函数,否者this就不是vm了

            4,methods中配置的函数,都是被vue所管理的函数,this的指向是vm 或 组件实例对象

            5,@click = 'demo' 和 @click = 'demo($event)' 效果一致,但后者可以传参

事件的写法

        1, 普通写法 v-on:click 现在点击按钮

                <button v-on:click = "showInfo">点我</button>

       2, 简写

                <button @click = "showInfo1">点我(不传参)</button>

       3,不传参

                 <button @click = "showInfo1">点我(不传参)</button>

      4,传参

                <button @click = "showInfo2($event,66)">点我(传参)</button>

 事件的回调需要配置在methods对象中的写法

methods:{

不传参的写法:

                showInfo1(event){     //event事件对象

                console.log(event),       //pointerEvent

                console.log(event.target),        //事件目标(元素botton)

                console.log(event.target.innerText),        //显示元素里面的文字

                console.log(this),        //这个里面的this就是vm

                console.log(this === vm),        //证明this就是vm的途径

                alert('您好!')

            },

在methods对象里不要用箭头函数

            // showInfo:(event)=>{  //在vue里面最好都用普通函数,箭头函数在此处不是最好的方法

            //     console.log(this)  //这里面的this就不是vm的,而是全局window的

            // }

传参的写法:

            showInfo2(event,number){

                console.log(event,number),

                alert('真棒')

            }

        }

二,事件修饰符 

            1,prevent:阻止默认事件(阻止跳转到指定的网页)(常用)

            2,stop:阻止事件冒泡(常用)

            3,once:事件只触发一次(常用)

            4,capture:使用事件的捕获模式

            5,self:只有event.target是当前操作的元素时才触发事件

            6,passive:事件的默认行为立即执行,无需等待事件回调执行完毕;(移动端用的比较多,多用于平板跟手机;@wheel.passive;@scroll可以不用)

分别演示一下事件修饰符的使用方法:

补充 阻止冒泡跟阻止跳转可以一起使用,@click.stop.prevent可以同时进行,位子可以随机放

 <div class="demo1" @click = "showInfo">    

            <a href="http://www.baidu.com" @click.stop.prevent = "showInfo">点击我</a>

       </div>

三、键盘事件

         1,vue中常用的按键别名

            回车=>enter

            删除=>delete (捕获:删除键 和 退格键)

            退出=>esc

            空格=>space

            换行=>tab(特殊,必须配合keydown.tab去使用)

            上=>up

            下=>down

            左=>left

            右=>right

        2,vue未提供别名的按键,可以使用按键原始的key值去绑定,但注意要转为kebab-case(短横线命名)

        3,系统修饰键(用法特殊):ctrl,alt,shift,meta(win键)

            (1)配合keyup使用:按下修饰键的同时,再按下其他键,随后释放其他键,事件才会触发;如按ctrl+y 松掉y才会触发事件

            (2)配合keydown使用:正常触发事件

        4,也可以使用keycode去指定具体的按键(不推荐)

        5,vue.config.keycodes.自定义键名 = 键码,可以去定制按键别名(不推荐)

分别演示一下键盘事件的使用方法:

 补充:系统修饰键ctrl.y这样的神仙组合避免啦ctrl.跟任何字母都能触发的情况

<div id="root">

        <input type="text" placeholder="按下回车提示输入" @keyup.ctrl.y = 'showInfo'>

</div>

感谢观看,欢迎随时反馈问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue.js 提供了一种简单的方式来处理 DOM 事件。你可以在 Vue 实例上使用 v-on 指令来监听 DOM 事件,并在触发事件时调用指定的方法。 例如,如果你想要在点击按钮时触发一个方法,你可以这样写: ```html <button v-on:click="doSomething">Click me</button> ``` 在这个例子中,v-on:click="doSomething" 表示当按钮被点击时,调用 Vue 实例中的 doSomething 方法。 除了 click 事件,你还可以监听其他的 DOM 事件,例如 mouseover、keydown 等等。你可以通过在 v-on 指令后面跟上事件名来监听这些事件。 另外,你还可以使用 @ 符号作为 v-on 的简写,例如: ```html <button @click="doSomething">Click me</button> ``` 这与上面的例子是等价的。 除了监听 DOM 事件外,你还可以在 Vue 实例中定义自定义事件,这些事件可以用来在组件间进行通信。要定义一个自定义事件,你可以使用 Vue 实例上的 $emit 方法。 例如,如果你想在某个组件中触发一个自定义事件,并将一些数据传递给其他组件,你可以这样写: ```javascript this.$emit('my-event', data); ``` 在这个例子中,'my-event' 表示自定义事件的名称,data 表示要传递给其他组件的数据。其他组件可以通过在模板中使用 v-on 指令来监听这个自定义事件,并在事件触发时调用指定的方法。 例如: ```html <my-component v-on:my-event="handleEvent"></my-component> ``` 在这个例子中,当 my-event 自定义事件被触发时,调用 Vue 实例中的 handleEvent 方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值