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。

相关推荐
winfredzhang20 小时前
打造专属桌面时钟:纯HTML实现的全功能动态时钟
前端·html·农历·生肖·周次
哥本哈士奇20 小时前
使用Gradio构建AI前端 - RAG的QA模块
前端·人工智能·状态模式
扶我起来还能学_20 小时前
Vue3 proxy 数据响应式的简单实现
前端·javascript·vue
Dragon Wu20 小时前
前端项目架构 项目格式化规范篇
前端·javascript·react.js·前端框架
QQ 313163789020 小时前
文华财经软件指标公式期货买卖信号提示软件
java·前端·javascript
狂龙骄子20 小时前
svg实现蚂蚁线动画
javascript·蚂蚁线动画·蚂蚁线·虚线动画
老华带你飞20 小时前
房屋租赁管理系统|基于java+ vue房屋租赁管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
惜晨宝贝21 小时前
文件上传格式限制
前端·html5·上传测试
IT_陈寒21 小时前
Vue3性能优化实战:7个被低估的Composition API技巧让渲染提速40%
前端·人工智能·后端
颖风船21 小时前
膨胀腐蚀及底层实践,拒绝opencv,matlab等方式
前端·opencv·matlab