Vue中的事件修饰符 键盘事件 监视属性watch 深度监视 简写

                        Vue中的事件修饰符

 1.Prevent:阻止默认事件(常用)

 @click.prevent阻止事件默认行为 

 <a href="http://www.baidu.com" @click.prevent=""showInfo>点击提示信息</a>

    2.stop:阻止事件冒泡

.stop  阻止事件冒泡 

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

           <button @click.stop="showInfo">点我提示信息</button>

        修饰符可以连续写

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

        </div>

    3.once:事件只触发一次

  .once:事件只触发一次

  <button @click.once="showInfo">点我提示信息1111</button>

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

                      .capture:使用事件的捕获模式 

        <div class="box1" @click.capture="showMsg(1)">

            div1

            <div class="box2" @click="showMsg(2)">

                div2

            </div>

        </div>

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

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

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

            <button @click="showInfo">点我提示信息</button>

         </div>

    6.passive:事件的默认行为立即执行,无需等待事件回调函数执行完毕

         .passive:事件的默认行为立即执行,无需等待事件回调函数执行完毕 

         scroll 滚动条   wheel滚动轮的滚动  @wheel.passive 

         <ul class="list" @scroll="demo">

             <li>1</li>

             <li>2</li>

             <li>3</li>

             <li>4</li>

         </ul>

                                  键盘事件

  1.Vue中常用的案件别名

        回车 => enter

        删除=> delect (捕获“删除”和“退格”)

        退出=>esc

        空格=>space

        换行=>tab  将焦点从当前元素移走  必须配合 keydown使用

        上=>up

        下=>down

        左=>left

        右=>right

 tab键将焦点从当前元素移走   

 @keyup.enter  不用写方法  用.enter 按下回车的时候会自动调用  不会输入一点调用一次

        @keyup.ctrl.y   同时点击 ctrl + y  才会调用 

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

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

 3.系统修饰键 ctrl alt shift meta

     (1).配合keyup使用 按下修饰键的同时 再按下其他键 随后释放其他键 事件才被触发

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

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

  @keyup.13  = @keyup.Enter

     5.Vue.confing.keyCodes.自定义键名 = 键码  可以去定制按键名

 Vue.config.keyCodes.huice = 13 //定义了一个别名按键

                      监视属性watch

 1.当监视的属性变化时 回调函数自动调用 进行相关操作

watch:{

   isHot:{

       immediate:true,       // 初始化时让handler调用一下

      handler(newValue,oldValue){        //handler什么时候被调用 当isHot值发生改变时

     console.log("isHot被修改了",newValue,oldValue);

          },

        }

    }

        2.监视属性的属性必须存在 才能进行监视

        3.监视的两种写法

        (1)new Vue时传入watch配置

        (2)通过vm.$watch监视

const vm = new Vue({

    el:"#root",

    data:{

        isHot:true,

        x:1,

    },

    computed:{

        info(){

         return this.isHot ? '炎热' :'凉爽'  

        }

    },

 vm.$watch('isHot',{

    immediate:true ,// 初始化时让handler调用一下

         handler(newValue,oldValue){         //handler什么时候被调用 当isHot值发生改变时

         console.log("isHot被修改了",newValue,oldValue);

          },

    })

                               深度监视

 (1).Vue中的watch默认不检测对象内部值的改变(一层)

        'numbers.a':{                   //监视多级结构中某个属性的变化

            handler(newValue,oldValue){

                console.log("a改变了");

            }

        },

        (2)配置deep:true可以检测对象内部值改变(多层)

        'numbers':{                                    //监视多级结构中所有属性的变化

            deep:true,                                               //深度监视

            handler(newValue,oldValue){

                console.log("numbers改变了");

            }

        }

        备注:

        (1)Vue自身可以检测对象内部值的改变但Vue提供的watch默认不可以

        (2)使用watch时根据数据的具体结构 决定是否采用深度监视

                                          简写

watch: {                                            //正常写法

                isHot:{

                immediate:true ,// 初始化时让handler调用一下

              handler什么时候被调用 当isHot值发生改变时

                handler(newValue,oldValue){

              console.log("isHot被修改了",newValue,oldValue);

                  },

              },

                isHot(newValue, oldValue) {                                //简写

                    console.log("isHot被修改了", newValue, oldValue);

                }

 vm.$watch('isHot',{

          immediate:true ,// 初始化时让handler调用一下

          handler什么时候被调用 当isHot值发生改变时

        handler(newValue,oldValue){

         console.log("isHot被修改了",newValue,oldValue);

              },

     })

简写

        vm.$watch('isHot',function(newValue,oldValue){

            console.log("isHot被修改了",newValue,oldValue);

        })

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,530评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,403评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,120评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,770评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,758评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,649评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,021评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,675评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,931评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,751评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,410评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,004评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,969评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,042评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,493评论 2 343

推荐阅读更多精彩内容