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

Posted tea_year

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue.js之v-show和v-if的区别相关的知识,希望对你有一定的参考价值。

<!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>

案例效果:

v-if的案例代码如下:

<!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>

案例效果如下:

区别
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 较好。

以上是关于vue.js之v-show和v-if的区别的主要内容,如果未能解决你的问题,请参考以下文章

vue使用v-if v-show页面闪烁,div闪现的解决方法

vue中v-show与v-if的区别

Vue.js常用指令:v-show和v-if

如何利用Vue.js库中的v-show显示和隐藏元素

v-if 和 v-show的区别

如何利用Vue.js库中的v-show显示和隐藏元素