Vue.js常用指令:v-show和v-if

news/2024/11/9 16:11:16

一、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" style="height:100px;width:300px;">
             </li>
         </ul>
    </div>
</body>
</html>

 运行效果:

将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:true,//布尔型 */
                    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" style="height:100px;width:300px;">
             </li>
         </ul>
    </div>
</body>
</html>

 运行效果:

这里只会显示三个<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" style="height:100px;width:300px;">
             </li>
         </ul>
    </div>
</body>
</html>

 运行效果:

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

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

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

v-show指令设置隐藏是为该元素添加css样式--display:none,但DOM元素还存在

v-if指令设置隐藏是将DOM元素整个删除,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:true,//布尔型 */
                    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" style="height:100px;width:300px;"> -->
                 <!--索引等于1的时候显示,索引不等于1的时候隐藏-->
                 <img :src="list" v-show="index==1" style="height:100px;width:300px;">
             </li>
         </ul>
    </div>
</body>
</html>

 检查元素:

从生成的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" style="height:100px;width:300px;"> -->
                  <!--索引等于1的时候显示,索引不等于1的时候隐藏-->
                  <img :src="list" v-if="index==1" style="height:100px;width:300px;">
             </li>
         </ul>
    </div>
</body>
</html>

 

检查元素:

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

更详细的区别:(借鉴别人博客内容,博客地址:https://www.cnblogs.com/wmhuang/p/5420344.html)

1.手段:v-if是动态的向DOM树内添加或者删除DOM元素;v-show是通过设置DOM元素的display样式属性控制显隐;
2.编译过程:v-if切换有一个局部编译/卸载的过程,切换过程中合适地销毁和重建内部的事件监听和子组件;v-show只是简单的基于css切换;
3.编译条件:v-if是惰性的,如果初始条件为假,则什么也不做;只有在条件第一次变为真时才开始局部编译(编译被缓存?编译被缓存后,然后再切换的时候进行局部卸载); v-show是在任何条件下(首次条件是否为真)都被编译,然后被缓存,而且DOM元素保留;
4.性能消耗:v-if有更高的切换消耗;v-show有更高的初始渲染消耗;
5.使用场景:v-if适合运营条件不大可能改变;v-show适合频繁切换。

http://www.niftyadmin.cn/n/4110986.html

相关文章

facebook文件系统_Facebook Messenger v4更新后在哪里可以找到请求文件夹

facebook文件系统When you get messages from non-friends on Facebook Messenger, they go to a “requests” folder. The thing is, this folder isn’t really easy to find, especially after Messenger’s recent update to version 4. 当您从Facebook Messenger上的非朋…

SQL SERVER 查询第一个数字和最后一个数字的位置

我们在实际开发中&#xff0c;有时候需要得到字符串中的数字位置&#xff0c;然后对字符串做处理。获取位置我们用PATINDEX方法&#xff0c;因为PATINDEX是支持正则表达式的&#xff0c;可以匹配数字&#xff0c;而类似CHARINDEX这种函数&#xff0c;只能查询匹配固定的字符串。…

php中 instanceof有什么作用

php中 instanceof有什么作用 作用&#xff1a;&#xff08;1&#xff09;判断一个对象是否是某个类的实例&#xff0c;&#xff08;2&#xff09;判断一个对象是否实现了某个接口。

学习Node.js笔记(一)

从最简单的一个node服务器开始说起 nodejs最常用的就是搭建服务器&#xff0c;今天就从0开始搭建自己的服务器&#xff0c;要想使用node来进行搭建服务器首先肯定是得下载node&#xff0c;直接百度一下node&#xff0c;从官网下载。下载完成后&#xff0c;直接安装软件就可以了…

SQL SERVER 90度行列互换

我们有时候在处理数据显示的时候&#xff0c;需要把之前的数据进行90度的行列互转&#xff08;注&#xff1a;不是行转列&#xff09;&#xff0c;数据处理起来比较麻烦&#xff0c;提供一个方法&#xff0c;测试数据&#xff1a; --测试数据 if not object_id(tab) is null d…

Java 8 lambda 表达式10个示例

Java 8 发布于4年前&#xff0c;日期是2014年3月18日&#xff0c;这次开创性的发布在Java社区引发了不少讨论&#xff0c;并让大家感到激动。特性之一便是随同发布的lambda表达式&#xff0c;它将允许我们将行为传到函数里。在Java 8之前&#xff0c;如果想将行为传入函数&…

siri快捷指令_如何查找和使用所有Siri快捷方式建议

siri快捷指令Siri Shortcuts arrived alongside iOS 12 in September 2018, along with the Shortcuts app and all that it entailed. The two features upped the iOS automation game considerably, but not without causing confusion. Here’s what Siri Shortcuts are, a…

解决Centos7下安装vsftpd问题

今天在一台新的服务器上安装vsftp时&#xff0c;使用yum安装&#xff0c;发现提示No package avaible。 后来找了半天&#xff0c;发现一个StackOverFlow上的教程。 先去https://fedoraproject.org/wiki/EPEL上下载对应版本的rpm包。 执行yum install dl.fedoraproject.org/pub…