Vue.js 学习笔记五:条件判断

目录

条件判断

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

用 key 管理可复用的元素

v-show


条件判断

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

使用见 Vue 基本使用 - 常用模板语法 - 指令操作

 

key 管理可复用的元素

Vue 会尽可能高效地渲染元素,通常会复用已有元素而不是从头开始渲染。这么做除了使 Vue 变得非常快之外,还有其它一些好处。例如,如果你允许用户在不同的登录方式之间切换:

		<div id="app">
				<label for="account" v-if="loginType== 'account'">
					account 
					<input type="text" id="account" placeholder="Enter your account"/>
				</label>
				<label for="email" v-if="loginType == 'email'">
					email 
					<input type="text" id="email" placeholder="Enter your email"/>
				</label>
				<button type="button" @click="toggleLoginType">切换登录方式</button>
		</div>
		<script type="text/javascript">
			const app =new Vue({
				el:'#app',
				data:{
					loginType:'account'
				},
				methods:{
					toggleLoginType(){
						this.loginType = this.loginType == 'account' ? 'email' : 'account'
					}
				}
			})
		</script>

如果我们在有输入内容的情况下,切换了类型,我们会发现文字依然显示之前的输入的内容。但是按道理讲,我们应该切换到另外一个 input 元素中了。在另一个 input 元素中,我们并没有输入内容。为什么会出现这个问题呢?

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

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

如果我们不希望 Vue 出现类似重复利用的问题,可以给对应的 input 添加 key,并且我们需要保证 key 的不同。

		<div id="app">
				<label for="account" v-if="loginType== 'account'">
					account 
					<input type="text" id="account" placeholder="Enter your account" key="account"/>
				</label>
				<label for="email" v-if="loginType == 'email'">
					email 
					<input type="text" id="email" placeholder="Enter your email" key="email"/>
				</label>
				<button type="button" @click="toggleLoginType">切换登录方式</button>
		</div>

 

v-show

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

		<div id="app">
			<p v-show="isShow">{{ msg }}</p>
		</div>
		<script type="text/javascript">
			const app =new Vue({
				el:'#app',
				data:{
					msg:'hello vue',
					isShow: true
					}
			})
		</script>

v-ifv-show 对比

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

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

一般来说,v-if 有更高的切换开销,而 v-show 有更高的初始渲染开销。

因此,如果需要非常频繁地切换,则使用 v-show 较好;如果在运行时条件很少改变,则使用 v-if 较好。

注意,v-show 不支持 <template> 元素,也不支持 v-else

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

stary1993

你的鼓励是我创作的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值