Vue基本语法(二)

简介: Vue基本语法(二)

九、事件监听



在前端开发中,我们需要经常和用于交互。


这个时候,我们就必须监听用户发生的时间,比如点击、拖拽、键盘事件等等

在Vue中如何监听事件呢?使用v-on指令


v-on介绍


作用:绑定事件监听器


缩写:@


预期:Function | Inline Statement | Object


参数:event


下面,我们就具体来学习v-on的使用。


1、v-on基础


这里,我们用一个监听按钮的点击事件,来简单看看v-on的使用

下面的代码中,我们使用了v-on:click="counter++”

另外,我们可以将事件指向一个在methods中定义的函数


image.png


image.png


注:v-on也有对应的语法糖:

v-on:click可以写成@click


image.png

image.png


image.png

image.png


2、v-on参数


当通过methods中定义方法,以供@click调用时,需要注意参数问题:

情况一:如果该方法不需要额外参数,那么方法后的()可以不添加。


但是注意:如果方法本身中有一个参数,那么会默认将原生事件event参数传递进去

情况二:如果需要同时传入某个参数,同时需要event时,可以通过$event传入事件。


image.png


image.png


image.png


image.png


3、v-on修饰符


在某些情况下,我们拿到event的目的可能是进行一些事件处理。


Vue提供了修饰符来帮助我们方便的处理一些事件:


.stop - 调用 event.stopPropagation()。


.prevent - 调用 event.preventDefault()。


.{keyCode | keyAlias} - 只当事件是从特定键触发时才触发回调。


.native - 监听组件根元素的原生事件。


.once - 只触发一次回调。


image.png


image.png


十、v-if、v-else-if、v-else


v-if、v-else-if、v-else


这三个指令与JavaScript的条件语句if、else、else if类似。


Vue的条件指令可以根据表达式的值在DOM中渲染或销毁元素或组件


简单的案例演示:


image.png


image.png


image.png


image.png


v-if的原理:


v-if后面的条件为false时,对应的元素以及其子元素不会渲染。

也就是根本没有不会有对应的标签出现在DOM中。


条件渲染案例


我们来做一个简单的小案例:


用户再登录时,可以切换使用用户账号登录还是邮箱地址登录。

类似如下情景:


image.png

image.png


image.png

image.png


image.png

image.png


案例小问题


小问题:

如果我们在有输入内容的情况下,切换了类型,我们会发现文字依然显示之前的输入的内容。


但是按道理讲,我们应该切换到另外一个input元素中了。


在另一个input元素中,我们并没有输入内容。


为什么会出现这个问题呢?


问题解答:


这是因为Vue在进行DOM渲染时,出于性能考虑,会尽可能的复用已经存在的元素,而不是重新创建新的元素。


在上面的案例中,Vue内部会发现原来的input元素不再使用,直接作为else中的input来使用了。


解决方案:


如果我们不希望Vue出现类似重复利用的问题,可以给对应的input添加key

并且我们需要保证key的不同


image.png

image.png


十一、v-show


v-show的用法和v-if非常相似,也用于决定一个元素是否渲染:

v-if和v-show对比

v-if和v-show都可以决定一个元素是否渲染,那么开发中我们如何选择呢?

v-if当条件为false时,压根不会有对应的元素在DOM中。

v-show当条件为false时,仅仅是将元素的display属性设置为none而已。

开发中如何选择呢?

当需要在显示与隐藏之间切片很频繁时,使用v-show

当只有一次切换时,通过使用v-if


image.png

image.png




相关文章
|
26天前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
127 1
|
5天前
|
JavaScript 安全 API
iframe嵌入页面实现免登录思路(以vue为例)
通过上述步骤,可以在Vue.js项目中通过 `iframe`实现不同应用间的免登录功能。利用Token传递和消息传递机制,可以确保安全、高效地在主应用和子应用间共享登录状态。这种方法在实际项目中具有广泛的应用前景,能够显著提升用户体验。
31 8
|
6天前
|
存储 设计模式 JavaScript
Vue 组件化开发:构建高质量应用的核心
本文深入探讨了 Vue.js 组件化开发的核心概念与最佳实践。
35 1
|
2月前
|
JavaScript 前端开发 开发者
vue 数据驱动视图
总之,Vue 数据驱动视图是一种先进的理念和技术,它为前端开发带来了巨大的便利和优势。通过理解和应用这一特性,开发者能够构建出更加动态、高效、用户体验良好的前端应用。在不断发展的前端领域中,数据驱动视图将继续发挥重要作用,推动着应用界面的不断创新和进化。
106 58
|
1月前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
2月前
|
JavaScript API 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
JavaScript 前端开发 开发者
Vue是如何劫持响应式对象的
Vue是如何劫持响应式对象的
66 18
|
2月前
|
JavaScript 前端开发 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
存储 JavaScript 前端开发
介绍一下Vue的核心功能
介绍一下Vue的核心功能
|
2月前
|
JavaScript 前端开发 API
介绍一下Vue中的响应式原理
介绍一下Vue中的响应式原理
49 1