霍格沃兹测试开发学社

《Python测试开发进阶训练营》(随到随学!)
2023年第2期《Python全栈开发与自动化测试班》(开班在即)
报名联系weixin/qq:2314507862

一文告诉你Vue的事件处理

Vue 事件处理

  • 使用 v-on 指令 (简写为 @) 来监听 DOM 事件,并在事件触发时执行对应的 JavaScript。
  • methods 承载多是事件函数
  • v-on 可以用 @替换

用法

v-on:click="methodName" 

@click="methodName"

事件处理器的值可以是:

内联事件处理器:事件被触发时执行的内联 JavaScript 语句 (与 onclick 类似)。

方法事件处理器:一个指向组件上定义的方法的属性名或是路径。

按钮点击操作

场景一

按钮点击对应前端控制台输出文本:

<script>
export default{
  name: 'app',
  data(){
  },
  methods:{
    clickHandle(){
      console.log("Hello 点击事件");
    }
  }

}
</script>
<template>
  <main>
    <div>
      <h1>事件处理</h1> 
      <button v-on:click="clickHandle">按钮</button>
      <button  @click="clickHandle">按钮</button>
    </div>

  </main>
</template>

  • 点击三次,前端页面控制台输出打印三次:Hello 点击事件

场景二

按钮点击,文本交替显示或消失

<script>
export default{
  name: 'app',
  data(){
  },
  methods:{
    clickHandle(){
      console.log("Hello 点击事件");
    },
    clickText(){
      this.flag = !this.flag;
    }
  }

}
</script>
<template>
  <main>
    <div>
      <h1>事件处理</h1> 
      <button v-on:click="clickHandle">按钮</button>
      <p v-if="flag">文本按钮显示</p>
      <button @click="clickText">文本按钮</button>
    </div>
  </main>
</template>

再次点击一次,按钮上文本消失。

在事件中改变文本是否显示的属性值,methods编写对应方法,索引到data属性内定义的值。

注意:所有data里面的属性都是通过this来索引修改

列表文本事件处理

场景一

<script>
export default{
  name: 'app',
  data(){
  },
  methods:{
    listHandle(e){
      console.log(e);
    }
  }
}
</script>
<template>
  <main>
    <div>
      <h1>事件处理</h1> 
      <button v-on:click="clickHandle">按钮</button>
      <p v-if="flag">文本按钮显示</p>
      <button v-on:click="clickText">文本按钮</button>
      <ul>
        <li @click="listHandle"  
          v-for="(value, key, index) in bookObj" :key="index" >
          {{index+1}}. {{key}} : {{value}}
        </li>
      </ul>
    </div>
  </main>
</template>
  • 传入参数e,对应前端页面控制台输出元素点击操作属性内容

场景二

对应文本传入事件进行处理

<script>
export default{
  name: 'app',
  data(){
  },
  methods:{
    clickHandle(){
      console.log("Hello 点击事件");
    },
    clickText(){
      this.flag = !this.flag;
    },
    listHandle(value){
      console.log(value);
    }
  }

}
</script>
<template>
<main>
    <div>
      <h1>事件处理</h1> 
      <ul>
        <li @click="listHandle(value)"  
          v-for="(value, key, index) in bookObj" :key="index" >
          {{index+1}}. {{key}} : {{value}}
        </li>
      </ul>
    </div>
  </main>
</template>
  • value代表方法传入的文本信息,不代表envent对象

即想传递参数又想传递envent对象

    listHandle(value,e){
      console.log(value,e);
    }

事件修饰符

修饰符是用 . 表示的指令后缀,包含以下这些:

  • .stop
  • .prevent:事件将不再重新加载页面
  • .self
  • .capture
  • .once
  • .passive

页面不跳转

  • 点击a标签,对应页面跳转失效
<script>
export default{
  name: 'app',
  data(){
  },
  methods:{
    clickHandle(){
      console.log("Hello 点击事件");
    }
  }

}
</script>
<template>
  <main>
    <div>
      <h1>事件处理</h1> 
      <a @click.prevent="clickHandle" href="https://www.baidu.com/">跳转页面</a>
    </div>

  </main>
</template>

posted @   霍格沃兹测试开发学社  阅读(23)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
历史上的今天:
2022-03-11 技术分享 | 这些常用测试平台,你们公司在用的是哪些呢?
点击右上角即可分享
微信分享提示