zoukankan      html  css  js  c++  java
  • Vue学习笔记4

    条件渲染

    v-if

        <div id="app">
            <template v-if="ok">
                <h1>Title</h1>
                <p>Paragraph 1</p>
                <p>Paragraph 2</p>
            </template>
        </div>
        <script>
            var vm = new Vue({
                el: '#app',
                data: {
                    message: "hello",
                    ok: true
                }
            })
        </script>
    
    

    v-else

        <div id="app">
            <div v-if="Math.random() > 0.5">
                Now you see me
            </div>
            <div v-else>
                Now you don't
            </div>
        </div>
        <script>
            var vm = new Vue({
                el: '#app',
            })
        </script>
    

    v-show

        <div id="app">
                <h1 v-show="ok">Hello!</h1>
        </div>
        <script>
            var vm = new Vue({
                el: '#app',
                data:{
                    ok:true
                }
            })
        </script>
    

    v-if vs v-show
    v-if 是“真正”的条件渲染,因为它会确保在切换过程中条件块内的事件监听器和子组件适当地被销毁和重建。

    v-if 也是惰性的:如果在初始渲染时条件为假,则什么也不做——直到条件第一次变为真时,才会开始渲染条件块。

    相比之下,v-show 就简单得多——不管初始条件是什么,元素总是会被渲染,并且只是简单地基于 CSS 进行切换。

    一般来说,v-if 有更高的切换开销,而 v-show 有更高的初始渲染开销。因此,如果需要非常频繁地切换,则使用 v-show 较好;如果在运行时条件很少改变,则使用 v-if 较好。

    v-ifv-for 一起使用
    v-ifv-for 一起使用时,v-for 具有比 v-if 更高的优先级。

  • 相关阅读:
    洛谷P3819 松江1843路
    洛谷P1896 [SCOI2005]互不侵犯King
    洛谷P1197 [JSOI2008]星球大战
    洛谷P1171 售货员的难题
    2017-10-24 NOIP模拟赛
    LibreOJ #6192. 「美团 CodeM 复赛」城市网络
    洛谷P2258 子矩阵
    Cogs 9. 中心台站建设
    Cogs 6. 线型网络
    洛谷P3138 [USACO16FEB]负载平衡Load Balancing_Silver
  • 原文地址:https://www.cnblogs.com/qfstudy/p/9315230.html
Copyright © 2011-2022 走看看