Vue - v-if、v-show、attribute key、v-else、v-else-if

推荐:Vue汇总

Vue - v-if、v-show、attribute key、v-else、v-else-if

v-if

根据表达式的真假值,来有条件地渲染元素。在切换时元素及它的数据绑定 、组件被销毁并重建。如果元素是 <template>,将提出它的内容作为条件块。

当条件变化时该指令触发过渡效果。

当和 v-if 一起使用时,v-for 的优先级比 v-if 更高。

代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>v-if v-show</title>
    <script src="./js/vue.js"></script>
</head>
<body>
    <div id="div">
        <ur>
            <li v-for="item in list" :key="item" v-if="show">{{item}}</li>
        </ur>
    </div>
</body>
</html>
<script>
    var vue = new Vue({
        el: '#div',
        data: {
            list: ['Jack' , 'Kaven', 'Java'],
            show: false
        }
    })
</script>

效果:
在这里插入图片描述
可见三个<li>标签被v-if给销毁了,所以v-for 的优先级比 v-if 更高,如果 v-if 优先级更高,v-for就不会起作用了,因为使用v-for的这个<li>标签会被销毁,就不会创建三个<li>标签,博主个人的理解,有错误可以评论告知博主。

<template> 元素上使用 v-if 条件渲染分组

因为 v-if 是一个指令,所以必须将它添加到一个元素上。但是如果想切换多个元素呢?此时可以把一个 <template> 元素当做不可见的包裹元素,并在上面使用 v-if。最终的渲染结果将不包含 <template> 元素。

代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>v-if v-show</title>
    <script src="./js/vue.js"></script>
</head>
<body>
<div id="div">
    <template v-if="show">
        <div>
            <p>Hello Kaven</p>
        </div>
        <div>
            <p>Hello World</p>
        </div>
        <div>
            <p>Hello Vue</p>
        </div>
    </template>
</div>
</body>
</html>
<script>
    var vue = new Vue({
        el: '#div',
        data: {
            show: true
        }
    })
</script>

效果:
在这里插入图片描述
可见渲染结果不包含 <template> 元素。

v-show

根据表达式的真假值,切换元素的 display CSS property

当条件变化时该指令触发过渡效果。

代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>v-if v-show</title>
    <script src="./js/vue.js"></script>
</head>
<body>
    <div id="div">
       <p v-show="show">{{message}}</p>
    </div>
</body>
</html>
<script>
    var vue = new Vue({
        el: '#div',
        data: {
            message: 'Hello Kaven',
            show: false
        }
    })
</script>

效果:
在这里插入图片描述
很显然是通过切换display CSS property来实现是否展示功能。

v-show 不支持 <template> 元素

代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>v-if v-show</title>
    <script src="./js/vue.js"></script>
</head>
<body>
<div id="div">
    <template v-show="show">
        <div>
            <p>Hello Kaven</p>
        </div>
        <div>
            <p>Hello World</p>
        </div>
        <div>
            <p>Hello Vue</p>
        </div>
    </template>
</div>
</body>
</html>
<script>
    var vue = new Vue({
        el: '#div',
        data: {
            show: false
        }
    })
</script>

效果:
在这里插入图片描述
可以看到<template> 元素不受v-show 的约束。

v-if vs v-show

  • v-if 是“真正”的条件渲染,因为它会确保在切换过程中条件块内的事件监听器和子组件适当地被销毁和重建。
  • v-if 也是惰性的:如果在初始渲染时条件为假,则什么也不做——直到条件第一次变为真时,才会开始渲染条件块。
  • 相比之下,v-show 就简单得多——不管初始条件是什么,元素总是会被渲染,并且只是简单地基于 CSS 进行切换。
  • v-show 不支持 <template> 元素,也不支持 v-else(这个很显然,因为v-else前一兄弟元素必须有 v-ifv-else-if,这个后面会进行介绍)。

一般来说,v-if 有更高的切换开销,而 v-show 有更高的初始渲染开销。因此,如果需要非常频繁地切换,则使用 v-show 较好;如果在运行时条件很少改变,则使用 v-if 较好。

节点复用

代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>v-if v-show</title>
    <script src="./js/vue.js"></script>
</head>
<body>
    <div id="div">
       <div v-if="show">
           注册:<input>
       </div>
        <div v-if="!show">
            登录:<input>
        </div>
    </div>
</body>
</html>
<script>
    var vue = new Vue({
        el: '#div',
        data: {
            show: false
        }
    })
</script>

效果:

输入字符串。
在这里插入图片描述
修改vue.show后,输入框被复用。
在这里插入图片描述
但这里我们不想要输入框被复用怎么办?我们可以使用key属性。

attribute key

key的特殊attribute主要用在Vue的虚拟DOM算法,在新旧nodes对比时辨识 VNodes。如果不使用 key,Vue会使用一种最大限度减少动态元素并且尽可能的尝试就地修改/复用相同类型元素的算法。而使用key时,它会基于key的变化重新排列元素顺序,并且会移除key不存在的元素。

有相同父元素的子元素必须有独特的key。重复的key会造成渲染错误。

它也可以用于强制替换元素/组件而不是重复使用它。当你遇到如下场景时它可能会很有用:

  • 完整地触发组件的生命周期钩子。
  • 触发过渡。

代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>v-if v-show</title>
    <script src="./js/vue.js"></script>
</head>
<body>
<div id="div">
    <div v-if="show">
        注册:<input :key="1">
    </div>
    <div v-if="!show">
        登录:<input :key="2">
    </div>
</div>
</body>
</html>
<script>
    var vue = new Vue({
        el: '#div',
        data: {
            show: false
        }
    })
</script>

效果:
在这里插入图片描述
这里输入框就没有被复用了。
在这里插入图片描述
v-else

前一兄弟元素必须有 v-ifv-else-if

代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>v-if v-show</title>
    <script src="./js/vue.js"></script>
</head>
<body>
    <div id="div">
       <div v-if="show">
           Hello World
       </div>
        <div v-else>
            Hello Kaven
        </div>
    </div>
</body>
</html>
<script>
    var vue = new Vue({
        el: '#div',
        data: {
            show: false
        }
    })
</script>

效果:
在这里插入图片描述
其实就是和编程语言里面的ifelse一样,那v-else-if的功能大家也就知道了。

v-else-if

代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>v-if v-show</title>
    <script src="./js/vue.js"></script>
</head>
<body>
    <div id="div">
        <div v-if="value === 'b'">
            This is b
        </div>
        <div v-else-if="value === 'a'">
            This is a
        </div>
        <div v-else>
            This is others
        </div>
    </div>
</body>
</html>
<script>
    var vue = new Vue({
        el: '#div',
        data: {
            value: 'a'
        }
    })
</script>

效果:
在这里插入图片描述
v-else前一兄弟元素必须有 v-ifv-else-if

代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>v-if v-show</title>
    <script src="./js/vue.js"></script>
</head>
<body>
    <div id="div">
        <div v-if="value === 'b'">
            This is b
        </div>
        <div v-else-if="value === 'a'">
            This is a
        </div>
        <div>Hello Kaven</div>
        <div v-else>
            This is others
        </div>
    </div>
</body>
</html>
<script>
    var vue = new Vue({
        el: '#div',
        data: {
            value: 'a'
        }
    })
</script>

报错:
在这里插入图片描述

写博客是博主记录自己的学习过程,如果有错误,请指正,谢谢!

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ITKaven

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值