首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >vue.js之v-show和v-if的区别

vue.js之v-show和v-if的区别

作者头像
张哥编程
发布2024-12-17 15:20:57
发布2024-12-17 15:20:57
3400
举报
文章被收录于专栏:云计算linux云计算linux
代码语言:javascript
复制
<!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>Document</title>
    <script src="./vue.js"></script>
</head>

<body>
    <div id="app">
        <p v-show="ok">显示</p>
        <p v-show="!ok">隐藏</p>
    </div>
    <script>
        let app = new Vue({
            el: '#app',
            data: {
                ok: true
            }
        });
    </script>
</body>

</html>

案例效果:

vue.js之v-show和v-if的区别_前端
vue.js之v-show和v-if的区别_前端

v-if的案例代码如下:

代码语言:javascript
复制
<!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>Document</title>
    <script src="./vue.js"></script>
</head>
<!-- v-if 变成了注释,操作是dom -->

<body>
    <div id="app">
        <p v-if="ok">显示</p>
        <p v-if="!ok">隐藏</p>
    </div>
    <script>
        let app = new Vue({
            el: '#app',
            data: {
                ok: true
            }
        });
    </script>
</body>

</html>

案例效果如下:

vue.js之v-show和v-if的区别_javascript_02
vue.js之v-show和v-if的区别_javascript_02

区别

1.手段:v-if是通过控制dom节点的存在与否来控制元素的显隐;v-show是通过设置DOM元素的display样式,block为显示,none为隐藏;

2.编译过程:v-if切换有一个局部编译/卸载的过程,切换过程中合适地销毁和重建内部的事件监听和子组件;v-show只是简单的基于css切换;

3.编译条件:v-if是惰性的,如果初始条件为假,则什么也不做;只有在条件第一次变为真时才开始局部编译(编译被缓存?编译被缓存后,然后再切换的时候进行局部卸载); v-show是在任何条件下(首次条件是否为真)都被编译,然后被缓存,而且DOM元素保留;

4.性能消耗:v-if有更高的切换消耗;v-show有更高的初始渲染消耗;

使用场景

基于以上区别,因此,如果需要非常频繁地切换,则使用 v-show 较好;如果在运行时条件很少改变,则使用 v-if 较好。

总结

v-if判断是否加载,可以减轻服务器的压力,在需要时加载,但有更高的切换开销;v-show调整DOM元素的CSS的dispaly属性,可以使客户端操作更加流畅,但有更高的初始渲染开销。

如果需要非常频繁地切换,则使用 v-show 较好;如果在运行时条件很少改变,则使用 v-if 较好。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-03-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档