• Vue官网教程-条件渲染


    通过v-if展示一个DOM是否显示

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

    改为false就不会显示了

    可以使用else的。

    <div v-if="ok">Hello World</div>
    <div v-else>Hello You</div>

    改变ok的值为false,注意这个false是没有''引号的,带引号的是字符串,没效果的

    因为v-if只能改变自己的DOM,如果想改变好几个标签要怎么办?

    可以使用template

    <div v-if="ok">Hello World</div>
    
            <template v-else>
                <div>Hello You</div>
                <div>Hello You</div>
                <div>Hello You</div>
            </template>

    v-else 要紧跟在v-if ,v-else-if后面!

     

    一句话,加上key值,key值不同,就会当作不同的元素,重新渲染。

    label没有key,所以label是复用的,只是改了innerHtml而已。

    自己写一下完整代码

    1、判断的时候,是使用全等哦! ===

    2、v-if后面跟的是表达式。v-if要用true和false

    <div id="app">
    
            <!-- 全等 === -->
            <!-- 双引号里面的字符串用单引号 -->
            <template v-if="loginType=== 'username'">
                <label>UserName</label>
                <input placeholder="UserName">
            </template>
    
            <template v-else>
                <label>Email</label>
                <input placeholder="Email">
            </template>
    
            <br>
            <button @click="handleClick">切换</button>
            
    
        </div>
    
        <script>
            var vm = new Vue({
                el:'#app',
                data:{
                    // 初始化
                    loginType:'username'
                },
                methods:{
                    handleClick:function (){
                        this.loginType === 'username'?this.loginType='email':this.loginType='username'
                    }
                }
            })
        </script>

     

    相比之下,v-show就菜了一些

    因为v-if,每次都要切换都要被创建和销毁!

  • 相关阅读:
    xcode5.1上真机调试报告No architectures to compile for...的解决办法
    Altium Designer元件库--多单元元器件的制作
    COMS门电路的设计及其优化--以异或门为例
    从器件物理层面看MOSFET的内部结构
    VHDL与Verilog硬件描述语言TestBench的编写
    C语言求解Excel地址转换问题
    数字黑洞求解问题
    计算机显示电池出现问题
    Charles安装
    滑动窗口1——无重复字符的最长字串
  • 原文地址:https://www.cnblogs.com/weizhibin1996/p/9535288.html
Copyright © 2020-2023  润新知