百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

Vue指令:v-if条件判断 vue v-if用法

bigegpt 2024-10-17 08:06 6 浏览

1.v-if指令

v-if指令是用来控制元素的切换显示

1.1 条件判断指令的基本使用

1.1.1 v-if 指令的基本使用

<!-- HTML --->
<div id="app">
    <h2 v-if="seen">你现在能看到我</h2>
</div>

<!-- JS --->
<script>
    const vm = new Vue({
        el: "#app",
        data: {
            seen:true
        }
    })
</script>

示例说明:

  1. 如果在控制台输入 vm.seen = false,你会发现之前显示的消息消失了。
  2. 因为v-if指令会根据seen的布尔值来判断当前h2需不需要显示
  3. 如果是其他数据类型会转为布尔值

1.1.2 v-else

看到这个是不是很熟悉,在JavaScript中,if流程控制语句中会有一个else,当条件为假的时候执行,.

那么既然在vue中有v-if指令来做添加判断,可定会有一个指令v-else来配合v-if条件为假的时候显示

示例: 使用 v-else 指令来表示 v-if 的“else 块”:

<div v-if="Math.random() > 0.5">
  你能看到我
</div>
<div v-else>
   你看不到我
</div>

注意事项:

  1. v-else 元素必须紧跟在带 v-if 或者 v-else-if 的元素的后面,否则它将不会被识别。


1.1.3 v-else-if 指令

v-else-if,顾名思义,充当 v-if 的“else-if 块”,可以连续使用:

示例代码:

<!-- app 是根容器  -->
<div id="app"><!---view--->
    <h2 v-if="err">网络连接错误</h2>
    <h2 v-else-if="success">网络连接成功</h2>

    <button @click="toggleError">Toggle Error</button>
    <button @click="toggleSuccess">Toggle Success</button>
</div>
<script>
    //实例化Vue对象
    const vm = new Vue({
        el: "#app",
        data: {
            err:false,
            success:false
        },
        methods: {
            toggleError(){
                this.err = !this.err
            },
            toggleSuccess(){
                this.success = !this.success
            }
        }
    })
</script>  

示例说明:

  1. 当数据中err为true时,显示v-if所在的DOM元素, v-else-if所在的DOM元素不会显示
  2. 当数据中err为false时,不显示v-if所在的DOM元素,
  3. 然后在根据v-else-if的判断条件是否为true,来决定是否显示所在的DOM元素


1.2 template标签

template标签, 是vue提供给我们的没有实际意义的,用来包裹元素的,


为什么需要template标签?

  1. 原因在于如果我需要多个标签同时显示或隐藏,我们就需要把这些标签包裹在同一标签里
  2. 如果不使用template标签,渲染出来结果就会多一层空标签

通过下面的示例来了解使用和不使用的不同.


1.2.1 未使用template标签

例如:

<div id="app"><!---view--->
    <div v-if="register">
        <h2>注册</h2>
        <input type="text" />
    </div>
    <div v-else>
        <h2 >登录</h2>
        <input type="text" />
    </div>

    <button @click="register = !register">{{register?"登录":"注册"}}</button>
</div>

<!-- js -->
<script>

    const vm = new Vue({
        el: "#app",
        data: {
            register: true
        }
    })
</script>

显示结果:

示例结果说明:

  1. 通过示例发现,会多出一层无用的div标签
  2. 如果这种写法在你的项目中过多,就会导致嵌套过多无用的层级标签


1.2.2 使用template标签

template标签在渲染的时候并不会渲染template标签,这个标签本身没有实际意义:

示例代码如下:

<div id="app">
    <!-- 默认情况下在切换dom时,相同的结构会被复用,如果不需要复用,需要加上key属性, -->
    <template v-if="cut">
        <label>注册</label>
        <input type="text" key="1" />
    </template>
    <template v-else>
        <label>登录</label>
        <input type="text" key="2"/>
    </template>
    
    <button @click="register = !register">{{register?"登录":"注册"}}</button>
</div>

显示结果:

通过示例可以直观的了解到,template标签没有被渲染, 也没有多出一层无用的标签


1.3. 用key管理可复用的元素

1.3.1 关于vue复用元素说明:

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

示例代码如下:

<div id="app"><!---view--->
    <template v-if="loginType === 'username'">
        <label>Username</label>
        <input placeholder="Enter your username">
    </template>
    <template v-else>
        <label>Email</label>
        <input placeholder="Enter your email address">
    </template>
    
    <button @click="loginType = loginType == 'username'? 'email':'username'">
        {{loginType=="username"?"邮箱登录":"用户名登录"}}
    </button>
</div>

那么在上面的代码中切换时 loginType 将不会清除用户已经输入的内容。
因为两个模板使用了相同的元素,<input> 不会被替换掉——仅仅是替换了它的 placeholder。

这样也不总是符合实际需求,
有的时候就需要让vue不复用我们的DOM元素.
因此 Vue 为你提供了一种方式来表示“这两个元素是完全独立的,不要复用它们”。
只需添加一个具有唯一值的 key 属性即可:

<template v-if="loginType === 'username'">
    <label>Username</label>
    <input placeholder="Enter your username" key="username-input">
</template>
<template v-else>
    <label>Email</label>
    <input placeholder="Enter your email address" key="email-input">
</template>


2.v-show 指令

2.1 v-show 指令的基本使用

另一个根据条件展示元素的指令是 v-show 指令。用法和v-if大致一样:

示例代码:

<h1 v-show="ok">Hello!</h1>


2.2 不支持template和v-else

注意,

  1. v-show 不支持 <template> 元素,
  2. v-show 指令不支持 v-else。如果使用会报错
<template v-show="false">
    <div>我很帅</div>
    <div>我很帅</div>
    <div>我很帅</div>
    <div>我很帅</div>
</template>

此时虽然v-show是false,但是template里面的div依然会显示在网页上,同时控制台并没有报错.


3. v-if VS v-show

3.1 v-if 和v-show不同

v-if 和v-show 指令都可以让元素显示或者隐藏,那么两个指令有什么不同呢?

当v-if判断位假时,整个元素都会从DOM节点上删除,并不算隐藏。不会在DOM节点上占位。

<div id="app">
    <div class="login" v-if="msg">登录</div>
    <div class="register" v-else>注册</div>
</div>

不管条件真假,login和 register 两个div元素在DOM节点上只会显示一个,另外一个不满足条件的会被从节点上删除

不同的是带有 v-show 的元素始终会被渲染并保留在 DOM 中。v-show 只是简单地切换元素的 CSS 属性 display。

<!-- app 是根容器  -->
<div id="app">
    <div class="login" v-show="msg">登录</div>
    <div class="register" v-show="!msg">注册</div>
</div>

v-show只是给元素添加了dispaly:block; 显示,元素即使不显示也依然在DOM节点上占位。


3.1 v-if 和v-show不同总结:

  1. v-if是“真正”的条件渲染,因为它会确保在切换过程中条件块内的事件监听器和子组件适当地被销毁和重建。
  2. v-if 也是惰性的:如果在初始渲染时条件为假,则什么也不做,直到条件第一次变为真时,才会开始渲染条件块。
  3. v-show 就简单得多,不管初始条件是什么,元素总是会被渲染,并且只是简单地基于 CSS 进行切换。
  4. 一般来说,v-if 有更高的切换开销,而 v-show 有更高的初始渲染开销。
  5. 因此,如果需要非常频繁地切换,则使用 v-show 较好;
  6. 如果在运行时条件很少改变,则使用 v-if 较好。

相关推荐

LangChain4j如何自定义文档转换器实现数据清洗?

LangChain4j提供了3种RAG(Retrieval-AugmentedGeneration,检索增强生成)实现,我们通常在原生或高级的RAG实现中,要对数据进行清洗,也就是将外接...

Java 8 Stream API 详解(java stream.)

Java8StreamAPI详解一、概述在Java8中,StreamAPI是一个重要的新特性。它为处理集合(如List、Set等)中的元素提供了一种高效且富有表现力的方式。Str...

Java修炼终极指南:185 使用 Stream 过滤嵌套集合

这是面试中的一个经典问题,通常从一个模型开始,如下所示(我们假设集合是一个List):publicclassAuthor{privatefinalStringname;pri...

java8的stream使用小示例(java stream())

据JetBrains发布的2021年开发者生态系统调查,Java8在java使用的版本中仍然是当前最流行的版本。72%的专业开发人员使用Java8作为其在java开发中主要编程语言版本。现...

Node.js Stream - 实战篇(node.js in action)

本文转自“美团点评技术团队”http://tech.meituan.com/stream-in-action.html背景前面两篇(基础篇和进阶篇)主要介绍流的基本用法和原理,本篇从应用的角度,介...

Java Stream:集合处理的api(java 集合操作)

JavaStream流:高效集合处理的函数式编程利器一、什么是JavaStream?Java8引入的StreamAPI是一套用于处理集合数据的流式编程接口,通过函数式风格(无副作用的...

去除 List 中的重复元素,你知道几种实现方法?

去除List中重复元素,这在实际编程或面试中经常遇到,每个人都有习惯的写法吧,这里抛砖引玉,汇总了一些实现方案,开拓思路。准备数据假设数组中有10个数据,可能有重复,需要将重复的数据从数组中去掉。pu...

Java开发者必看!Stream流式编程10个爆款技巧,让你代码优雅飞起

为什么你的Java代码总像拧巴的麻绳?掌握这10个Stream实战技巧,代码效率与优雅度将产生质的飞跃。以下案例均来自真实电商系统场景,带你感受流式编程的降维打击!一、过滤与映射组合拳(Filter...

leetcode每日一题之存在重复元素(存在重复元素 iii)

题:给定一个整数数组,判断是否存在重复元素。如果存在一值在数组中出现至少两次,函数返回true。如果数组中每个元素都不相同,则返回false。比如:输入:[1,2,3,1]输出:true...

告别for循环!揭秘Stream API如何让你的代码简洁度提升300%

一、当传统循环遇上现代需求真实场景复现:某电商平台需要处理10万条订单数据,要求:筛选出金额>500的订单提取用户ID并去重统计VIP用户数量传统实现方案://常规写法Set<Long...

Java中List去重的N种方法:从基础到优雅

Java中List去重的N种方法:从基础到优雅在日常的Java开发中,我们经常会遇到需要对List集合去重的情况。无论是为了清理重复的数据,还是为了优化算法性能,掌握多种去重方式都是一项非常实用的技能...

Java Stream流没用过?常用高频方法

概念Stream流是Java8添加的以一种链式调用的方法处理数据,主要侧重于计算。具有以下相关特点代码简洁链式调用Stream常用方法1.将数组变为当作List操作String[]strArr=...

核医学专业名词索引(M-R)(核医学重点归纳)

M吗啡(morphia)埋藏式心律转复除颤器(implantablecardioverterdefibrillator,ICD)麦角骨化醇(VD2,calciferol)脉冲堆积(pulsepi...

CodeMeter 新版发布(codesigner下载)

威步于2022年8月4日发布CodeMeter7.50及CodeMeter软件保护套装11.10,以下为新版内容。CodeMeterRuntime7.50StreamingSIMDExten...

世界上最小的五轴铣床Pocket NC(最小的五轴加工中心)

PocketNC,由MIT学生研制,还有说法是这款产品的设计者是来自美国蒙大拿州的一对极客夫妻。目前主要有两款产品:PocketNCV2-50,9000美元;PocketNCV2-10,60...