条件渲染:
1.v-if
写法:
(1).v-if=“表达式”
(2).v-else-if=“表达式”
(3).v-else=“表达式”
适用于:切换频率较低的场景。
特点:不展示的DOM元素直接被移除。
注意: v-if可以和:v-else-if、 v-else起使用, 但要求结构不能被“打断”。
2。V-show
写法: v-show=” 表达式"
适用于:切换频率较高的场景。
特点:不展示的DOM元素未被移除,仅仅是使用样式隐藏掉
3.备注:使用v-if的时,元素可能无法获取到,而使用v-show定可以获取到。
代码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>条件渲染</title>
<script type="text/javascript" src="../js/vue.js"></script>
<link rel="shortcut icon" href="../ico—全图标/application/Finder.ico" type="image/x-icon">
</head>
<body>
<div id="root">
<h2>当前的n值是:{{n}}</h2>
<button @click="n++">点我n+1</button>
<!-- 使用v-show做条件渲染 -->
<!-- <h2 v-show="false">海口欢迎{{name}}</h2> -->
<!-- <h2 v-show="1 === 1">海口欢迎{{name}}</h2> -->
<!-- 使用v-if做条件渲染 -->
<!-- <h2 v-if="false">海口欢迎{{name}}</h2> -->
<!-- <h2 v-if="1 === 1">欢迎来到{{name}} -->
<!-- v-else 和 v-else-if -->
<div v-if="n === 1">AAA</div>
<div v-else-if="n === 2">BBB</div>
<div v-else-if="n === 3">CCC</div>
<div v-else>DDD</div>
<!-- v-if与template的配合使用 -->
<template v-if="n === 1">
<h3>海口</h3>
<h3>欢迎</h3>
<h3>您</h3>
</template>
</div>
</body>
<script type="text/javascript">
Vue.config.productionTip = false
const vm = new Vue({
el:'#root',
data:{
name:'您',
n:0
}
})
</script>
</html>
结果: