vue--v-if和v-show的区别(个人项目中的理解应用)
在面试的时候,一道vue基础到不能再基础的面试题叫做v-if与v-show的区别,当然答案网上一搜一大堆,基本两句话就能说明:
1.相同点:都是根据指令是否渲染该组件
2.不同点:v-if仅重新渲染当次,v-show相当于元素的display属性,只是样式上的显示或者隐藏。
这导致了它们的使用场景(不细致可以考虑不存在)不同,前者多用于使用渲染次数较少的环境,需要反复渲染的多用v-show,v-if会加大服务器压力等等。。
这里说项目当中遇到的几个场景:
1.使用v-if或者v-show做一个tab选项卡的切换
毫无疑问,这种场景下用v-show,因为一个选项卡中用户需要频繁切换,次数可能还相当大。当时在项目的需求当中,后端接口和前端这一块并不能做到tab1中的某个数据改变后,用户切换到tab2
后与这个数据相关的另一个数据即时改变,因为这两个tab是组件不是两个不同的页面,没法在create中重新刷新数据。
可行的方法是通过组件传值,可这样就很麻烦了,这里将父组件中的v-show换
成v-if,重新渲染当前组件,起到了一个局部渲染的作用。
2.需要用v-for渲染一组数据,data拿着一看600多条需要根据某一字段从大到小排列,一个屏幕才11,12条,很明显后边的就不用显示了,就显示前一百条吧,先v-if试试

不让连用,换成v-show就好了
3.使用v-show做一个点击到footer的5个按钮时分别显示不同的页面,相当于大组件
页面上就像调转到几个不同的页面(常见的app那种),但这里需求其实是一个页面中展示的不同组件!
在做每个页面(其实是组件)右侧边栏有一个按钮一直存在,点击时左侧均能划出80%宽的其他组件,所以得在5个组件都引入这个组件,而这个组件又恰巧因为内部某一部分只能展示展示在这几个
组件中的个别组件,这里的问题就是每次点击footer切换组件时,左侧都会划出其他组件的里的cover(现象是这样)。
可行方法是把左侧划出的组件拆了重写,也要改父组件,就相当于把山都挖了,
恐怖,效果还未知。。。。打印组件传值时发现cover的flag为true打印了五次,感觉是flag被每个组件重复传值了,所以在父组件中将v-show改用v-if,就像是将五个组件转换成5个页面,每次点击只
传值一次,,,,,,,解决了。
至于之后可能出现的问题,先不想。。。不想就没有问题
vue--v-if和v-show的区别(个人项目中的理解应用)的更多相关文章
- 缓存框架有使用过哪些?memcache和redis有什么区别?项目中,怎么去选择?
缓存有:ehcache,memcache和redis等 区别: 1. Redis和Memcache都是将数据存放在内存中,都是内存数据库.不过memcache还可用于缓存其他东西,例如图片.视频等等. ...
- session与cookie的区别以及HTML5中WebStorage理解
一.session与cookie的区别 二.HTML5中WebStorage理解 WebStorage的目的是克服由cookie所带来的一些限制,当数据需要被严格控制在客户端时,不需要持续的将数据发回 ...
- vue 快速入门 系列 —— 使用 vue-cli 3 搭建一个项目(下)
其他章节请看: vue 快速入门 系列 使用 vue-cli 3 搭建一个项目(下) 上篇 我们已经成功引入 element-ui.axios.mock.iconfont.nprogress,本篇继续 ...
- FFmpeg笔记--vcodec和-c:v,-acodec和-c:a的区别?
在看ffmpeg命令的时候经常会看到有些地方使用--vcodec指定视频解码器,而有些地方使用-c:v指定视频解码器,那这两个有没有区别呢? ffmpeg的官方文档: -vcodec codec (o ...
- 转:oracle几组重要的常见视图-v$latch,v$latch_children,v$lock,v$locked_object
v$latch Oracle Rdbms应用了各种不同类型的锁定机制,latch即是其中的一种.Latch是用于保护SGA区中共享数据结构的一种串行化锁定机制.Latch的实现是与操作系统相关的, 尤 ...
- oracle 入门笔记--v$sql和v$sqlarea视图(转载)
转载于作者:dbtan 原文链接:http://www.dbtan.com/2009/12/vsql-and-vsqlarea-view.html v$sql和v$sqlarea视图: 上文提到,v$ ...
- vue 的computed 和 watch 两者的区别
computed是计算属性,依赖其他属性计算,并且computed的值有缓存,只有当计算值发生变化才会返回内容. computed 用来监控自己定义的变量,该变量不在data里面声明,直接在compu ...
- Oracle基本数据字典:v$database、v$instance、v$version、dba_objects
v$database: 视图结构: SQL> desc v$database; Name Null? Type - ...
- POJ2762 Going from u to v or from v to u(单连通 缩点)
判断图是否单连通,先用强连通分图处理,再拓扑排序,需注意: 符合要求的不一定是链拓扑排序列结果唯一,即在队列中的元素始终只有一个 #include<cstdio> #include< ...
- Going from u to v or from v to u?_POJ2762强连通+并查集缩点+拓扑排序
Going from u to v or from v to u? Time Limit: 2000MS Memory Limit: 65536K Description I ...
随机推荐
- [Vue warn]: Unknown custom element: <el-row> - did you register the component correctly? For recursi
babel.config.js 文件中 module.exports = { presets: [ '@vue/cli-plugin-babel/preset' ] } 替换为 module.expo ...
- java中 YYYY与yyyy 区别
大多数情况下格式日期都是用的SimpleDateFormat,比如说把一个日期格式成"yyyy-MM-dd"的形式. 对于年份来说,大写的Y和小写的y其意义是不同的. y 是Yea ...
- SpringBoot集成LDAP同步数据
1.pom引入依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId& ...
- KingbaseES V8R6 集群运维案例-- sys_internal.init.*文件引起sys_basebackup失败
案例说明: KingbaseES V8R6集群在执行'repmgr standby clone'或sys_basebackup克隆备库时出现如下图相关sys_internal.init文件错误: 适用 ...
- #min-max容斥#51nod 1355 斐波那契的最小公倍数
题目 对于 \(n\leq 50000,a_i\leq 10^6\),求 \(\large lcm(fib(a_1),fib(a_2),\dots,fib(a_{n-1}),fib(a_n))\) 分 ...
- #Tarjan#洛谷 4819 [中山市选]杀人游戏
题目 分析 缩点后显然只考虑入度为0的点的个数, 但是问题是如果有一个入度为0的点缩点前只有1个点 且它的出边上的所有点都可以被其它入度为0的点遍历, 那么可以将其它点全部排除后剩下的这个点就是凶手, ...
- OpenHarmony嵌套类对象属性变化:@Observed装饰器和@ObjectLink装饰器
上文所述的装饰器仅能观察到第一层的变化,但是在实际应用开发中,应用会根据开发需要,封装自己的数据模型.对于多层嵌套的情况,比如二维数组,或者数组项class,或者class的属性是class,他们的第 ...
- Python - 字典2
Python - 访问字典项 您可以通过在方括号内引用其键名来访问字典的项: 示例,获取 "model" 键的值: thisdict = { "brand": ...
- Python - 字典1
字典用于存储键值对形式的数据.字典是一个有序.可更改的集合,不允许重复.从 Python 3.7 版本开始,字典是有序的.在 Python 3.6 及更早版本中,字典是无序的.字典用花括号编写,具有键 ...
- C#中超链接方法
linkLabel控件:双击事件打开网页:System.Diagnostics.Process.Start("http://www.baidu.com"); 截图: