购买
下载掌阅APP,畅读海量书库
立即打开
畅读海量书库
扫码下载掌阅APP

4.2.1 v-if

v-if指令根据表达式的真假来有条件地渲染元素。

【例4.10】v-if指令(源代码\ch04\4.10.html)。

    <div id="app">
        <h3 v-if="ok">冰箱</h3>
        <h3 v-if="no">洗衣机</h3>
        <h3 v-if="num>=1000">库存很充足!</h3>
    </div>
    <!--引入vue文件-->
    <script src="https://unpkg.com/vue@next"></script>
    <script>
        //创建一个应用程序实例
        const vm= Vue.createApp({
            //该函数返回数据对象
            data(){
              return{
                 ok:true,
                 no:false,
                 num:1000
               }
            }
            //在指定的DOM元素上装载应用程序实例的根组件
         }).mount('#app');
    </script>

在谷歌浏览器中运行程序,按F12键打开控制台,并切换到 “Elements”选项,结果如图4-13所示。

图4-13 v-if指令

在上面示例中,使用v-if="no"的元素并没有被渲染,使用v-if="ok"的元素正常渲染了。也就是说,当表达式的值为false时,v-if指令不会创建该元素;只有当表达式的值为true时,v-if指令才会真正创建该元素。这与v-show指令不同,v-show指令不管表达式的真假,元素本身都会被创建,显示与否是通过CSS的样式属性display来控制的。

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

点击中间区域
呼出菜单
上一章
目录
下一章
×