vuejs中v-if的深层用法v-else,v-else-if,key
<div id='root'> <div v-if='show'>helle world</div> <button @click='handleClick'>toggle</button> </div> <script> new Vue({ el:'#root', data:{ show:true }, methods:{ handleClick:function(){ this.show = !this.show; } } }) </script>
v-if,里面这个show是个变量,如果是true就是显示,如果是false就不显示,这里是移除了dom
有if,就有else
<div id='root'> <div v-if='show'>helle world</div> <div v-else>bye world</div> </div> <script> var vm = new Vue({ el:'#root', data:{ show:true } }) </script>
这里v-if,v-else要紧贴着使用,不然会报错,v-if显示,v-else就会隐藏。v-if隐藏,v-else就会显示
v-else-if
<div id='root'> <div v-if='show==="a"'>this is a</div> <div v-else-if='show==="b"'>this is b</div> <div v-else>this is others</div> </div> <script> var vm = new Vue({ el:'#root', data:{ show:'a' } }) </script>
这里可以根据show的值进行不同的处理,这三个也要紧贴着写,中间不能被其他所分隔
v-if使用的时候key值的用法
<div id='root'> <div v-if='show'> 用户名:<input type="text" /> </div> <div v-else> 邮箱名:<input type="text" /> </div> </div> <script> var vm = new Vue({ el:'#root', data:{ show:false } }) </script>
这个例子,在我们使用的时候,show的值变为true,发现邮箱名已经变成了用户名,但是input框里面的值却没变空,这是因为vuejs有一种尝试复用dom的机制,如果已经在的dom,会复用之前的dom,但是这并不是我们想要的效果,这个时候就可以给他加一个key值,告诉vuejs,这是唯一的,是不能复用的input
<div id='root'> <div v-if='show'> 用户名:<input type="text" key='userName'/> </div> <div v-else> 邮箱名:<input type="text" key='password' /> </div> </div> <script> var vm = new Vue({ el:'#root', data:{ show:false } }) </script>
这个时候,当show变为true的时候,邮箱名变了,后面的input也变了
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架