v-if条件渲染及v-show的选择

文章目录

v-if条件渲染

v-if条件渲染,即在template中使用if-else逻辑表达式选择是否渲染某一变量。

v-if 、v-else 两者结合使用实现二选一,代码如下:

复制代码
<template>
	<view>
		<view  v-if="shop">京东</view>
		<view v-else>淘宝</view>
	</view>
</template>

<script setup>
	import {ref} from "vue" ;
	const shop = true
</script>

<style lang="scss" scoped>
	       
</style>

在这段代码中,shop变量为真,因此显示"京东",否则显示"淘宝"。

v-if、v-else搭配v-else-if实现多选一,代码如下:

复制代码
<template>
	<view>
		<view v-if = "day === 1">星期一</view>
		<view v-else-if = "day === 2">星期二</view>
		<view v-else-if = "day === 3">星期三</view>
		<view v-else-if = "day === 4">星期四</view>
		<view v-else-if = "day === 5">星期五</view>
		<view v-else-if = "day === 6">星期六</view>
		<view v-else-if = "day === 7">星期日</view>
		<view v-else >错误</view>
	</view>
</template>

<script setup>
	import {ref} from "vue" ;
	const day = ref(4);
</script>

<style lang="scss" scoped>
	       
</style>

根据day变量的值,会渲染出不同的v-else-if内容,若day没有对应的值,则渲染条件else报错。

v-if条件渲染和v-show的选择

两者条件为假时,实际显示效果其实是一样的,但内部运行方式不同。

v-if为假,该元素就不会被渲染,也就是说不会占用资源;v-show为假,元素依然会被渲染,只是它是以display属性加载的,依然会占用资源。另外,v-show 不支持在 template元素上使用,也不能和 v-else 搭配使用。

template元素

v-if必须依附于某个元素使用,但如果我们想让它作用于多个元素呢?可以用template给它打包起来,这是一种包装器元素,在最终的渲染结果中并不会显示template。

相关推荐
tecwlcvi323几秒前
安卓版谷歌地图,Google地图高清版,谷歌地球,谷歌翻译,谷歌(Chrome)浏览器,手机版Edge,浏览器等安卓版浏览器下载
前端·chrome·edge
czlczl200209251 分钟前
SpringBoot中web请求路径匹配的两种风格
java·前端·spring boot
用户555970025103 分钟前
Vue学习笔记-项目结构与文件结构分析
vue.js
码途潇潇5 分钟前
Vue3 + TS + TailwindCSS 操作引导组件开发逐行解析
vue.js
2022.11.7始学前端8 分钟前
n8n第四节 表单触发器:让问卷提交自动触发企微消息推送
java·前端·数据库·n8n
m0_740043738 分钟前
Axios 请求示例 res.data.data
前端·javascript·vue.js
程序员小寒10 分钟前
超详细的 EventLoop 解读及模拟实现
前端·javascript
冴羽12 分钟前
太好看了!3 个动漫变真人 Nano Banana Pro 提示词
前端·人工智能·aigc
zReadonly13 分钟前
关于vxeTable转换树状表格以及问题思考
前端
锈儿海老师14 分钟前
深入探究 React 史上最大安全漏洞
前端·react.js·next.js