文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Vue.js中v-show和v-if指令怎么用

2023-06-29 12:24

关注

小编给大家分享一下Vue.js中v-show和v-if指令怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

一、v-show指令

v-show指令可以用来动态的控制DOM元素的显示或隐藏。v-show后面跟的是判断条件,语法如下:

v-show="判断变量"

例如:

v-show="true",表示显示DOM元素。

v-show="false", 表示隐藏DOM元素。

看下面的示例:

<!DOCTYPE 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>v-show指令</title>    <!--引入vue.js-->    <script src="node_modules/vue/dist/vue.js" ></script>    <script>       window.onload=function(){           // 构建vue实例           new Vue({               el:"#my",               data:{                      flag:true,//布尔型                      imgList:["img/banner1.jpg","img/banner2.jpg","img/banner3.jpg"]               },               // 方法               methods:{               }           })       }    </script></head><body>    <div id="my">         <ul>             <li v-for="list in imgList">                 <img :src="list" v-show="flag" >             </li>         </ul>    </div></body></html>

运行效果:

Vue.js中v-show和v-if指令怎么用

将flag变量改为false,代码如下:

<!DOCTYPE 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>v-show指令</title>    <!--引入vue.js-->    <script src="node_modules/vue/dist/vue.js" ></script>    <script>       window.onload=function(){           // 构建vue实例           new Vue({               el:"#my",               data:{                                        flag:false,//布尔型                    imgList:["img/banner1.jpg","img/banner2.jpg","img/banner3.jpg"]               },               // 方法               methods:{               }           })       }    </script></head><body>    <div id="my">         <ul>             <li v-for="list in imgList">                 <img :src="list" v-show="flag" >             </li>         </ul>    </div></body></html>

运行效果:

Vue.js中v-show和v-if指令怎么用

这里只会显示三个<li元素>,但不会显示img元素。

二、v-if指令

v-if指令的用法和v-show指令的用法相同,都是用来控制DOM元素的显示或隐藏。代码示例如下:

<!DOCTYPE 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>v-if指令</title>    <!--引入vue.js-->    <script src="node_modules/vue/dist/vue.js" ></script>    <script>       window.onload=function(){           // 构建vue实例           new Vue({               el:"#my",               data:{                    flag:true,//布尔型                     imgList:["img/banner1.jpg","img/banner2.jpg","img/banner3.jpg"]               },               // 方法               methods:{               }           })       }    </script></head><body>    <div id="my">         <ul>             <li v-for="list in imgList">                 <img :src="list" v-if="flag" >             </li>         </ul>    </div></body></html>

运行效果:

Vue.js中v-show和v-if指令怎么用

三、v-show和v-if的区别

v-show和v-if都可以用来控制DOM元素的显示或隐藏,那么这两个指令有什么区别呢?

v-show和v-if指令的区别主要在于设置DOM元素隐藏的时候:

看下面的示例:

v-show设置隐藏:

<!DOCTYPE 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>v-show指令</title>    <!--引入vue.js-->    <script src="node_modules/vue/dist/vue.js" ></script>    <script>       window.onload=function(){           // 构建vue实例           new Vue({               el:"#my",               data:{                                        flag:false,//布尔型                    imgList:["img/banner1.jpg","img/banner2.jpg","img/banner3.jpg"]               },               // 方法               methods:{               }           })       }    </script></head><body>    <div id="my">         <ul>             <li v-for="(list,index) in imgList">                 <!-- <img :src="list" v-show="flag" > -->                 <!--索引等于1的时候显示,索引不等于1的时候隐藏-->                 <img :src="list" v-show="index==1" >             </li>         </ul>    </div></body></html>

检查元素:

Vue.js中v-show和v-if指令怎么用

从生成的HTML结构中可以看出,索引不等于的元素被隐藏了,只是添加了CSS样式:display:node,但是该元素还存在。下面看看v-if

<!DOCTYPE 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>v-if指令</title>    <!--引入vue.js-->    <script src="node_modules/vue/dist/vue.js" ></script>    <script>       window.onload=function(){           // 构建vue实例           new Vue({               el:"#my",               data:{                    flag:true,//布尔型                     imgList:["img/banner1.jpg","img/banner2.jpg","img/banner3.jpg"]               },               // 方法               methods:{               }           })       }    </script></head><body>    <div id="my">         <ul>             <li v-for="(list,index) in imgList">                 <!-- <img :src="list" v-if="flag" > -->                  <!--索引等于1的时候显示,索引不等于1的时候隐藏-->                  <img :src="list" v-if="index==1" >             </li>         </ul>    </div></body></html>

检查元素:

Vue.js中v-show和v-if指令怎么用

从生成的HTML结构中可以看出,索引不等于1的元素被隐藏了,这里是直接删除了img元素,不占用位置。

更详细的区别:(借鉴别人博客内容,博客地址://www.yisu.com/article/240646.htm)

四、v-else指令

v-else指令不需要表达式,但有一个限制条件:前一兄弟元素必须有v-if或者v-else-if指令。

用法:为v-if或者v-else-if添加“else 块”。

看下面的代码:

<!DOCTYPE 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>Vue指令:v-if v-else</title>    <!--引入vue.js-->    <script src="./js/vue.js"></script></head><body>    <div id="app">        <h2>num值:{{num}}</h2>        <div v-if="num > 5" id="div1">             Now you see me        </div>        <!--v-else指令不需要表达式,配合前面的v-if使用-->        <div v-else>            Now you don't        </div>    </div>    <script>            // 实例化Vue对象            var vm = new Vue({                // 挂载元素                el:"#app",                data:{                    num:Math.random()                },                methods:{                     }            });         </script></body></html>

浏览器运行结果:

Vue.js中v-show和v-if指令怎么用

可以看到:num的值不大于5,所以v-if表达式的值为false,所以会显示v-else指令所在标签。

五、v-else-if

v-else-if使用限制:前一兄弟元素必须有v-if或者v-else-if。

用法:v-else-if表示v-if的“else-if”块,可以链式调用。

看下面代码:

<!DOCTYPE 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>Vue指令:v-if v-else</title>    <!--引入vue.js-->    <script src="./js/vue.js"></script></head><body>    <div id="app">        <!-- <h2>num值:{{num}}</h2>        <div v-if="num > 5" id="div1">             Now you see me        </div> -->        <!--v-else指令不需要表达式,配合前面的v-if使用-->        <!-- <div v-else>            Now you don't        </div> -->        <div v-if="type === 'A'">             A         </div>        <div v-else-if="type === 'B'">             B        </div>        <div v-else-if="type === 'C'">            C        </div>        <div v-else>            Not A/B/C        </div>    </div>    <script>            // 实例化Vue对象            var vm = new Vue({                // 挂载元素                el:"#app",                data:{                    num:Math.random(),                    type: 'B'                },                methods:{                     }            });         </script></body></html>

浏览器运行结果:

Vue.js中v-show和v-if指令怎么用

以上是“Vue.js中v-show和v-if指令怎么用”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯