zoukankan      html  css  js  c++  java
  • vue基础---08事件

    00.表达式

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
        <script src="../js/vue.js"></script>
    </head>
    <body>
        <div id="app">
            <h1>{{count}}</h1>
            通过表达式完成事件操作</br>
            <button @click="count++">点击</button></br>
            通过事件对象</br>
            <button @click="clickEvent">点击1</button>
    
        </div>
        <script type="text/javascript">
            var app=new Vue({
                el:"#app",
                data:{
                    count:0
                },
                methods:{
                    clickEvent:function(event){
                        this.count++;
                    }
                }
            })
        </script>
    </body>
    </html>

    01.事件传参

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
        <script src="../js/vue.js"></script>
    </head>
    <body>
        <div id="app">
            <ul>
                事件传参,下面的参数与methods中的参数对应,注意:传事件对象是$event格式
                <li v-for="item,index in name" @click="clickEvent(item,index,$event)">
                    索引值:{{index}}-----姓名:{{item}}
                </li>
            </ul>
        </div>
        <script type="text/javascript">
            var app=new Vue({
                el:"#app",
                data:{
                    name:['蔡徐坤','范冰冰','李晨']
                },
                methods:{
                    clickEvent:function(item,index,event){
                        alert(index);
                        alert(item);
                        alert(event);
                    }
                }
            })
        </script>
    </body>
    </html>

    02.修饰符

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
        <script src="../js/vue.js"></script>
    </head>
    <body>
        
        <div id="app">
            .stop:阻止冒泡事件向上继续传播
            <div class="btnParent" @click=" clickParent">
                <!-- 如果去掉.stop,就会产生冒泡,触发两次 -->
                <button @click.stop="clickEvent">按钮</button>
            </div>
    
    
    
            .prevent:阻止默认事件
            <!-- 下面代码在没有添加阻止事件前,会发生默认行为(请求服务器失败的代码) -->
            <form action="" method="post">
                <input type="text" name="username" id="" value="">
                <input @click.prevent="searchWeather" type="submit" value="提交">
            </form>
    
    
    
    
            .once:只触发一次
            <button @click.once="onceEvent">按钮</button>
        </div>
        <script type="text/javascript">
            var app=new Vue({
                el:"#app",
                data:{
    
                },
                methods:{
                    clickEvent:function(event){
                        console.log('clickEvent');
                    },
                    clickParent:function(){
                        console.log("clickParent");
                    },
                    searchWeather:function(){
                        console.log("阻止默认事件");
                    },
                    onceEvent:function(){
                        console.log("只触发一次");
                    }
                }
            })
        </script>
    </body>
    </html>

    03.自定义按键码

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
        <script src="../js/vue.js"></script>
    </head>
    <body>
        自定义按键码
    
        <div id="app">
            <form action="">
    
                <!-- 只有按回车见才会触发(闪一下) -->
                <input type="text" @keydown.f1="searchWeather" name="username" value="" >
            </form>
        </div>
        <script type="text/javascript">
        // 配置自定义修饰符f1
        Vue.config.keyCodes.f1 = 112
            var app=new Vue({
                el:"#app",
                data:{
    
                },
                methods:{
                    searchWeather:function(){
                        console.log("查询天气");
                    }
                }
            })
        </script>
    </body>
    </html>
  • 相关阅读:
    [算法][求积分][复合辛普森公式]
    [51单片机] SPI nRF24L01无线 [可以放在2个单片机里实现通信]
    [51单片机] SPI nRF24L01 无线简单程序 1
    [stm32] 利用uC-BmpCvt软件生成uc-gui可调用的bmp图片
    [stm32] 利用uc-gui封装画图和画线函数移植51上的模拟动画
    [stm32] 中断
    [C++] 将 mp3 等音乐资源以资源形式嵌入 exe 文件中
    [游戏学习28] MFC 时钟
    [游戏学习27] MFC 匀速运动
    [游戏学习26] MFC 时间函数 画图形
  • 原文地址:https://www.cnblogs.com/hunter1/p/15250797.html
Copyright © 2011-2022 走看看