Vue-条件渲染和循环渲染

2023-11-10

文章目录


条件渲染

条件渲染指令是用来辅助开发者控制DOM的显示与隐藏。条件渲染指令有如下两个,分别是:
v-show和v-if
v-show和v-if的区别:
v-show是通过动态的为元素添加或移除display:none来进行显示与隐藏。如果需要频繁切换元素的显示状态,用v-show性能会更好。
v-if是通过动态的创建或移除元素来实现元素的显示和隐藏。如果不需要频繁切换元素的显示状态,用v-if性能会更好。
v-if配套的指令:
v-else-if 跟else if使用差不多
v-else 跟else使用差不多

    <script src='https://lf6-cdn-tos.bytecdntp.com/cdn/expire-1-M/vue/2.6.14/vue.js'></script>
</head>
<style>
    .div1 {
        width: 200px;
        cursor: pointer;
    }
</style>
<body>
    <div class="myH">
        <div class="div1" @click="fn">
            <p>点我展示下拉框</p>
        </div>
        <div class="div1" v-show="flag">
            <p>下拉框一</p>
            <p>下拉框一</p>
        </div>
        <div class="div1" v-if="age<18">
            <span>
            未年人
            </span>
        </div>
        <div v-else-if="age>=18">
            <span>
                成年人
            </span>
        </div>
    </div>
    <script>
        var vue = new Vue({
            el: ".myH",
            data: {
                flag: false,
                age:22
            },
            methods: {
                fn() {
                    this.flag = !this.flag
                },
            }
        })
    </script>

请添加图片描述

循环渲染

1.v-for循环普通数组:v-for=“(em,index) in arr1”
2.v-for循环对象数组:v-for=“(em,index) in arr2”
3.v-for迭代对象:v-for=“(em, index) in arr3”
4.v-for迭代数字:v-for=“count in 10”

<style>
.div1{
    display: inline-block;
}
</style>

<body>
    <div class="myH">
        <!--v-for循环普通数组-->
        <div  v-for="(em, index) in arr1" :key="index" class="div1" style="background-color: royalblue;">
            <p>{{em}}</p>
        </div>

        <!--v-for循环对象数组-->
        <div  v-for="(em, index) in arr2" :key="index" class="div1" style="background-color: aqua;">
            <p>{{em.name}}
               {{em.age}}
               {{em.like}}
            </p>
        </div>

        <!-- v-for迭代对象 -->
        <div v-for="(em, index) in arr3" :key="index" class="div1" style="background-color: rgb(7, 146, 146);">
           {{em}}
        </div>

        <!--v-for迭代数字; in 后面我们放过数组、对象数组、对象,还可以放数字-->
        <!-- 如果使用v-for迭代数字的话,前面 count 的值从 1 开始-->
        <div style="background-color: rgb(185, 218, 218);">
         <p v-for="count in 10" class="div1">第{{count}}次</p>
        </div>
    </div>
    <script>
        var vue = new Vue({
            el: ".myH",
            data: {
                arr1: [5,4,3,2,1],
                arr2: [{name: "ljy",age: 21,like: "健身"}, 
                      {name: "jack",age: 11,like: "游泳"}, 
                      {name: "mary",age: 25,like: "爬山"}, 
                      {name: "Arali",age: 33,like: "美食"
                }],
                arr3:{
                    name: "jack", age: 11, like: "游泳"
                }
            },
        })
    </script>

在这里插入图片描述

v-for中key的意义
vue在刷新页面组件时,会把旧节点跟新vm节点做比较,如果要增加节点,并不会删除旧节点,而是复用;这样会导致节点跟数据没有绑定关系而重新渲染,用key可以将数据与节点绑定起来。

    <div id="app">
        <h1>活动:从10件商品中选择5件商品作为奖励</h1>
        <button type="button" @click="add">加载新的商品</button>
        <button>提交</button>
        <div>
            <div v-for=" (item,index) in arr" :key="item.id">
                <input type="checkbox" name="goods" />
                {{item.name}}
            </div>
        </div>
    </div>

    <script type="text/javascript">
        new Vue({
            el: "#app",
            data: {
                arr: [
                    { id: 10001, name: "商品1", },
                    { id: 10002, name: "商品2", },
                    { id: 10003, name: "商品3", },
                    { id: 10004, name: "商品4", }
                ],
                count: 5
            },
            methods: {
                add() {
                    //网络请求 然后把新商品添加到arr中
                    //假装网络请求了新数据	
                    var result = this.count++
                    this.arr.unshift({ id: result, name: "商品" + result})
                }
            }
        })
    </script>

在这里插入图片描述

for和if同一个标签bug:
当for和if放在了同一个标签中 没有先后顺序的要求,但是先执行for
渲染过程为:对arr每一项先做map循环判断v-if给出的条件,再做一遍for 循环渲染
这样引起的问题是:arr 数组新增一项数据时,会对每一项再做一遍v-if 循环,然后for 循环渲染

解决方案把for弄到最外层
如果if和for套在一层,数据容器发生变化时,if会重新判断一遍
嵌套的写法 数据容器变化时 if只判断新增的数据
这样当arr 数组某一项数据发生变化时,只对新增的数据进行v-if 判断,节约渲染效率

这样又会产生新的问题:外层for的div会也创建一个挂载到DOM中
解决方案:wx采用的是block元素 vue呢? template 其实就是dom操作中的fragment

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Vue-条件渲染和循环渲染 的相关文章

随机推荐

  • gerrit push (change closed)解决办法

    Remember DESKTOP MEFCTAV MINGW64 Desktop VFC vnfres master git push origin HEAD refs for master Enumerating objects 27 d
  • docker 全局日志控制

    vim etc docker daemon json log driver json file log opts max size 1g max file 1 max size 500m 意味着一个容器日志大小上限是500M max fil
  • 网站主题切换

    文章目录 网站主题切换 前言 思路 全部写在 style 属性中 全部写在外部 css 文件中 引用不同的 link 文件 通过 class 命名空间的方式 webpack 插件 webpack theme color replacer 实
  • 【论文翻译+笔记】Neural Machine Reading Comprehension: Methods and Trends

    1 Introduction 过去的MRC技术的特点 hand crafted rules or features 缺点 不能泛化 performance may degrade due to large scale datasets of
  • ADC转换不准确?启用内部参考电压缓冲器 (VREFBUF)

    电压基准缓冲器VREFBUF 一 VREF 描述 1 VDDA 有时与VREF 键合 2 VREF 与 VREF 3 VREF 作用 二 VREFBUF 电压参考缓存器 1 简介 2 功能描述 3 VREFBUF 修边 三 VREFBUF寄
  • 【第40篇】TransFG:用于细粒度识别的 Transformer 架构

    TransFG 用于细粒度识别的 Transformer 架构 摘要 介绍 相关工作 细粒度视觉分类 Transformer 方法 视觉转换器作为特征提取器 TransFG 架构 实验 实验设置 消融研究 定性分析 结论 摘要 论文地址 h
  • stm32cubemx使用mpu6050

    文章目录 接线图 代码 常见问题 接线图 一般情况下 大家买的 mpu 6050 有两种 1 就是 单个的 mpu6050 芯片 2 就是 mpu6050 模块 如果 是第一种情况的话 大家可以参考 下图所示 如果是第二种情况的话 一般来说
  • 简易自动电阻测试仪

    这次练习的题目是2011年的简易自动电阻测试仪 设计并制作一台简易自动电阻测试仪 要求就是测量量程为 100 1k 10k 10M 四档 并且前三档可以自动切档 3 位数字显示 最大显示数必须为 999 能自动显示小数点和单位 测量速率大于
  • Feign简介与简单应用

    一 点睛 Feign是Netflix开发的声明式 模板化的HTTP客户端 Feign可以帮助我们更快捷 优雅地调用HTTP API 在Spring Cloud中 使用Feign非常简单 创建一个接口 并在接口上添加一些注解 代码就完成了 F
  • 注册小鲸鱼88888专用网站

    点击注册充值即可 高效不限速 不限设备 注意这里的地址并没有错 只是你需要想办法正确能进入就行 懂的大佬一定知道用一定的方法访问的 有问题的话可以邮箱 grantwtt 163 com
  • Warning: failed to get default registry endpoint from daemon

    操作系统 CentOS 7 执行命令 docker info docker search docker pull 执行用户 非root 有sudo权限 Docker报错 1 报错现象及原因 2 其它报错 3 配置docker开机自启动 1
  • FFmpeg进阶: 音频变声滤镜

    声音最重要的两个元素就是语速和语调 改变声音的辨识度主要也是从这两方面入手 我们可以通过对音频数据进行插值或者抽值修改 以达到降低语速和增加语速的目的 同时我们也可以通过对数据进行线性拉伸来调节音调 语速调整 语调调整 就可以让我们的声音千
  • QtCreator编译 fatal error: Killed signal terminated program cc1plus问题解决

    原因 编译器消耗的内存超过了系统的限制 强制停止了 解决方式 减少编译时进程数量 make j4
  • 数学建模 层次分析法 python计算权重

    这里用python语言来计算判断矩阵的权重 网上大部分是matlab语言 里面也包含一致性检验的函数 具体各函数使用方法详见代码注释的部分 import numpy as np a np array 1 1 4 2 1 3 4 1 8 2
  • ==和equals的区别

    1 在八种基本类型中 比较的是值的本身 eg public class Damo2 public static void main String args int str 10 int str1 10 System out println
  • ROS navigation的学习和分析

    ROS navigation功能包简单来说就是输入传感器信息和机器人位姿 通过导航算法输出机器人的速度控制指令实现机器人的2D路径规划 贴出代码库 navigation github官方仓库 以下是ROS官方的文档 navigation官方
  • avue-crud 组件,form中实现树形下拉框联动输入框数据,省市区字典联动

    1 需要实现的功能是 当我选择一条数据的时候 后面几个输入框会自动带入 使用的是avue crud组件 参数配置
  • 数据结构--环形队列的介绍与实现

    数据结构 环形队列实现 一 环形队列实现原理 环形队列的几个判断条件 二 代码实现 1 环形队列类 CircleQueue 2 环形队列类测试类 3 程序运行结果 4 完整代码 环形队列可以用数组实现 也可以使用循环链表实现 在使用数组实现
  • 2023前端面试题总结(vue,react)

    Vue 1 MVC与MVVM的区别 MVC和MVVM的区别并不是VM完全取代了C ViewModel存在目的在于抽离Controller中展示的业务逻辑 而不是替代Controller 其它视图操作业务等还是应该放在Controller中实
  • Vue-条件渲染和循环渲染

    文章目录 条件渲染 循环渲染 条件渲染 条件渲染指令是用来辅助开发者控制DOM的显示与隐藏 条件渲染指令有如下两个 分别是 v show和v if v show和v if的区别 v show是通过动态的为元素添加或移除display non