Vue-条件渲染和循环渲染


条件渲染

条件渲染指令是用来辅助开发者控制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

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
vue-element-admin是一个基于Vue.js和Element UI的后台管理系统模板,它使用了Vue的组件化开发方式来实现页面渲染。 在vue-element-admin中,页面渲染主要通过以下几个步骤实现: 1. 路由配置:通过Vue Router进行路由配置,定义了每个页面对应的路由路径和组件。当用户访问某个路由路径时,对应的组件会被加载和渲染。 2. 组件开发:每个页面都是一个独立的组件,通过Vue的单文件组件(.vue文件)来开发。在组件中,可以定义模板(HTML结构)、样式(CSS)和逻辑(JavaScript)。 3. 数据获取:在组件中,可以通过Vue的生命周期钩子函数(如created、mounted等)来发送异步请求获取数据。一般情况下,可以使用Vue Resource、Axios等库来发送HTTP请求,并将获取到的数据保存在组件的data属性中。 4. 数据绑定:通过Vue数据绑定语法,将组件的data属性中的数据与模板进行绑定。这样,在数据发生变化时,模板会自动更新。 5. 条件渲染循环渲染:通过Vue的指令(如v-if、v-for等)来实现条件渲染循环渲染。根据不同条件数据,动态地显示或隐藏某些元素,或者重复渲染某个元素。 6. 事件处理:通过Vue的指令(如v-on)来绑定事件处理函数,实现对用户操作的响应。当用户触发某个事件(如点击、输入等)时,对应的事件处理函数会被调用。 7. 样式设置:通过CSS样式来设置页面的外观和布局。可以使用Element UI提供的组件和样式,也可以自定义样式。 总结起来,vue-element-admin通过Vue的组件化开发方式,结合Vue Router、数据绑定、条件渲染循环渲染、事件处理等特性,实现了页面的动态渲染和交互效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

H5_ljy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值