目录
v-if是判断是否将DOM元素显示出来
不满足条件的元素,会直接删除,不会存在浏览器上面
也是用来判断,是否将DOM元素在页面上显示,但是与v-if有着区别,它的不显示是通过display:none;实现的,还是存在浏览上。
- "app">
- <h2 v-if="age<18">未成年h2>
- <h2 v-else-if="age<60">壮年h2>
- <h2 v-else>老年h2>
- <h2 v-show="flag">showh2>
- <h2 v-if="flag">ifh2>
- div>
-
- <script src="./vue.js">script>
- <script>
- let vm = new Vue({
- el:"#app",
- data(){
- return{
- age:71,
- flag:false//true会显示,false不会显示
- }
- }
- })
- script>
如下图片显示,不存在时v-if和v-show的显示状态
可以发现show是被display:none;影藏起来了
if已经从这个世界上消失了
案例
这里用简单的if判断,可以通过按钮控制不同的输入模式
这里也会出现一个细节上的问题,因为Vue会出现大量的复用情况,所以这里需要在input表单中设置一个key值,使其出现差别,在以输入内容的表单,切换后内容会也会被取消掉。
- <div id="app">
- <span v-if="usname">
- <label for="uname">用户名label>
- <input type="text" id="username" placeholder="输入用户名" key="index">
- span>
- <span v-else="usname">
- <label for="email">用户名邮箱label>
- <input type="text" id="email" placeholder="输入邮箱" key="index1">
- span>
- <button @click="usname=!usname">选择button>
- div>
- <script src="./vue.js">script>
- <script>
- let vm = new Vue({
- el:"#app",
- data(){
- return{
- usname:true
- }
- }
- })
- script>
二、循环语句
如下案例
遍历数组
是通过循环来实现点击变色,这里遍历出了下标和内容,在页面上显示出来
v-for="(item,index) in list"
item值index索引
- <style>
- .active{
- color: red;
- }
- style>
- head>
- <body>
- <div id="app">
- <ul>
- <li :class="currentIndex==index?'active':''" @click="change(index)" v-for="(item,index) in list">{{index}}--{{item}}li>
- ul>
- div>
- <script src="./vue.js">script>
- <script>
- let vm = new Vue({
- el:'#app',
- data(){
- return {
- currentIndex:0,
- list:["海王","海贼王","火影忍者","复仇者联盟"],
- }
- },
- methods:{
- change(index){
- this.currentIndex=index
- }
- }
- })
- script>
- body>
遍历对象
- html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
- <meta http-equiv="X-UA-Compatible" content="ie=edge">
- <title>Documenttitle>
- head>
- <body>
- <div id="app">
-
-
- <ul>
- <li v-for="(item,key) in user" >{{key+"-"+item}}li>
- ul>
-
- <ul>
- <li v-for="(item,key,index) in user" >{{key+"-"+item+"-"+index}}li>
- ul>
-
- div>
- <script src="https://cdn.jsdelivr.net/npm/vue@2.6.10/dist/vue.js">script>
- <script>
- const app = new Vue({
- el:"#app",
- data:{
- user:{
- name:"zzz",
- height:188,
- age:24
- }
- }
- })
- script>
- body>
- html>
三、v-if和v-for的注意事项
如果将v-if和v-for 在同一个标签内使用,会出现每次先循环,在去判断渲染,在性能上出现了浪费
要注意这个细节,在写代码时,可以将for包含到if判断中,使其不在一个标签内,从而避免了同是使用的情况。
这里,还会出现一个问题,如果使用index为索引,在渲染表单的时候就会出现,表单添加,表单内容没有出现变化,需要自己起一个唯一标志符。