推荐: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-if
或v-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-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="show">
Hello World
</div>
<div v-else>
Hello Kaven
</div>
</div>
</body>
</html>
<script>
var vue = new Vue({
el: '#div',
data: {
show: false
}
})
</script>
效果:
其实就是和编程语言里面的if
、else
一样,那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-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>Hello Kaven</div>
<div v-else>
This is others
</div>
</div>
</body>
</html>
<script>
var vue = new Vue({
el: '#div',
data: {
value: 'a'
}
})
</script>
报错:
写博客是博主记录自己的学习过程,如果有错误,请指正,谢谢!