vue的学习总结---事件处理

v-on的理解

监听DOM元素的事件,并在触发时执行一些js代码
<template>
  <div>
    <!-- v-on监听DOM事件,并在触发时做一些js的操作,如下代码可以将js操作直接放在事件中 -->
    <button v-on:click="num++">点击按钮+1</button>
    <h3>{{ num }}</h3>
  </div>
</template>
<script>
export default {
  data() {
    return {
      num: 1
    };
  },
  methods: {}
};
</script>

效果如图:

 

 

 如果js操作比较简单,可以直接将js操作代码放到事件后面,但是一般js操作都会具有一定的逻辑性,所以可以在事件后面添加一个方法名,然后在methods中编写js操作代码,如下

<template>
  <div>
    <!-- v-on监听DOM事件,并在触发时做一些js的操作,如下代码可以将js操作直接放在事件中 -->
    <button v-on:click="addNum">点击按钮+1</button>
    <h3>{{ num }}</h3>
  </div>
</template>
<script>
export default {
  data() {
    return {
      num: 1,
      name: "vue.js"
    };
  },
  methods: {
    addNum: function(event) {
      //这个event也需要注意 如果模板中也就是template中事件后边仅仅是方法名,没有带括号
      //那么在js中这个event是默认存在的 这个event代表的是这个DOM元素 也可以打印看一下内容
      this.num++;
      //这里需要注意了 this指的是vue实例 可以进行打印
      console.log(this);
      console.log(this.name);
      console.log(event);
      console.log(event.target.tagName); //获取目标DOM元素的标签名
    }
  }
};
</script>

打印结果:

 

 

 

 

内联处理器

<template>
  <div>
    <!--注意了,这次跟之前又不一样了,这次方法加了个括号,并且传递了参数 -->
    <button v-on:click="say('Hi')">say Hi</button>
    <button v-on:click="say('What')">say What</button>
  </div>
</template>
<script>
export default {
  data() {
    return {
      num: 1,
      name: "vue.js"
    };
  },
  methods: {
    say: function(msg) {
      console.log(msg);
    }
  }
};
</script>

点击后的效果:

 

 

 这时候需要想一下,之前事件后面的方法名不带括号,可以直接在js中使用event,那么现在括号并且带参数了,还能直接使用吗?可以先试一下,直接在方法中打印event,代码如下

<template>
  <div>
    <!--注意了,这次跟之前不一样了,这次方法加了个括号,并且传递了参数 -->
    <button v-on:click="say('Hi')">say Hi</button>
    <button v-on:click="say('What')">say What</button>
  </div>
</template>
<script>
export default {
  data() {
    return {
      num: 1,
      name: "vue.js"
    };
  },
  methods: {
    say: function(msg, event) {
      console.log(msg);
      console.log(event);
    }
  }
};
</script>

打印结果:

 

 于是就看出来这两者是有区别的,事件后边的方法不带括号,在js中可以直接调用默认自带的event,但是内联处理器,也就是带括号的,就不能直接使用默认自带的event。那么如果想要在内联处理器中使用event呢,俗话说有钱好办事,给个美刀($)就可以了,代码如下

<template>
  <div>
    <!--注意了,$event是不加括号的哟 -->
    <button v-on:click="say('Hi', $event)">say Hi</button>
    <button v-on:click="say('What', $event)">say What</button>
  </div>
</template>
<script>
export default {
  data() {
    return {
      num: 1,
      name: "vue.js"
    };
  },
  methods: {
    say: function(msg, event) {
      console.log(msg);
      console.log(event);
    }
  }
};
</script>

效果如图:

 

 总结一下:

1、事件绑定方法时,如果带括号(不管有没有参数),那么这就是内联处理器。
2、事件绑定方法时,带括号和不带括号的区别,带括号可以传递参数,不带括号就不行了
3、当模板中事件后边方法名带括号,并且有$event参数时,js中写方法也不一定必须加上event

如下代码:

<template>
  <div>
    <!--注意了,这次跟之前不一样了,这次方法加了个括号,并且传递了参数 -->
    <button v-on:click="say('Hi', $event)">say Hi</button>
    <button v-on:click="say('What', $event)">say What</button>
  </div>
</template>
<script>
export default {
  data() {
    return {
      num: 1,
      name: "vue.js"
    };
  },
  methods: {
    say: function(msg) { //这里并没有接收event参数
      console.log(msg);
      console.log(event);
    }
  }
};
</script>

效果如下:

 

 

 

事件修饰符:

  .stop

在不适用修饰符的时候,代码如下:

<template>
  <div>
    <div v-on:click="toDo1">
      <h3>div1</h3>
      <div v-on:click="toDo2">
        <h3>div2</h3>
        <div v-on:click="toDo3"><h3>div3</h3></div>
      </div>
    </div>
  </div>
</template>
<script>
export default {
  data() {
    return {
      num: 1,
      name: "vue.js"
    };
  },
  methods: {
    toDo1: function() {
      console.log("DIV1被触发");
    },
    toDo2: function() {
      console.log("DIV2被触发");
    },
    toDo3: function() {
      console.log("DIV3被触发");
    }
  }
};
</script>

效果如图:

 

 添加.stop修饰之后,就可以阻止冒泡事件的发生,代码如下:

<template>
  <div>
    <div v-on:click="toDo1">
      <h3>div1</h3>
      <div v-on:click="toDo2">
        <h3>div2</h3>
        <div v-on:click.stop="toDo3"><h3>div3</h3></div>
      </div>
    </div>
  </div>
</template>
<script>
export default {
  data() {
    return {
      num: 1,
      name: "vue.js"
    };
  },
  methods: {
    toDo1: function() {
      console.log("DIV1被触发");
    },
    toDo2: function() {
      console.log("DIV2被触发");
    },
    toDo3: function() {
      console.log("DIV3被触发");
    }
  }
};
</script>

效果如图:

 

 总结:

.stop修饰符,可以阻止冒泡事件的发生,阻止事件继续传播

 

  .capture

不使用修饰符时,效果在上边已经展示,接下来就直接看这个capture修饰符的效果,代码如下:

<template>
  <div>
    <div v-on:click="toDo1">
      <h3>div1</h3>
      <!--在div2事件中添加了capture修饰符-->
      <div v-on:click.capture="toDo2">
        <h3>div2</h3>
        <div v-on:click="toDo3"><h3>div3</h3></div>
      </div>
    </div>
  </div>
</template>
<script>
export default {
  data() {
    return {
      num: 1,
      name: "vue.js"
    };
  },
  methods: {
    toDo1: function() {
      console.log("DIV1被触发");
    },
    toDo2: function() {
      console.log("DIV2被触发");
    },
    toDo3: function() {
      console.log("DIV3被触发");
    }
  }
};
</script>

效果如下:

 

 总结:

使用capture修饰符之后,会先冒泡到带capture的事件,然后再由内到外进行触发。在举个例子,在原来基础上里面再添加一层div4,capture还是绑定在div2上,点击div4,触发顺序是 div2->div4->div3>div1

  .

事件修饰符的作用以及在js中的表现

在js中通常使用,event.preventDefault(),阻止事件默认动作的发生。
event.stopPropagation(),阻止传播事件的发生

js中加on和不加on的区别

加on时,代表直接使用方法
不加on时,是动态指定方法

系统修饰键

  .ctrl

当事件添加系统修饰键时,就必须结合系统按键才能触发事件,代码如下:

<template>
  <div>
    <button v-on:click.ctrl="toDo1">BUTTON</button>
  </div>
</template>
<script>
export default {
  methods: {
    toDo1: function() {
      console.log("必须同时按住CTRL键button才能被触发");
    }
  }
};
</script>

效果如下:此时必须按住ctrl键才能触发点击事件

 

 但是还有一个问题,就是在按住ctrl的同时,再按住alt键或者shift键,一样可以触发,于是就没有那么准确了,这时就可以用下边的系统修饰键修饰符

 

系统修饰键修饰符

  .exact

添加这个修饰符之后就可以更加精确了,只有按住ctrl键才能够触发,再多按住其他键就不会被触发。

以上修饰符并未全部列出,详细信息链接:https://cn.vuejs.org/v2/guide/events.html

本文主要是理解为主,其他未列出的如果有兴趣也可以一一尝试。

总结v-on的优点:

1、在模板中事件后边添加方法名,可以更快的定位到js中的具体方法
2、无需在js中动态操作DMO元素绑定方法,和DOM完全解耦
3、跟ViewModel同生同死,ViewModel被销毁时,所有的方法也会被销毁

viewmodel的销毁下一步需要查一下????

 

posted @ 2021-03-09 23:17  背着泰山找黄河  阅读(120)  评论(0编辑  收藏  举报