vue.js中for循环如何实现异步方法同步执行

 更新时间:2024年02月28日 09:34:23   作者:Lemon今天学习了吗  
这篇文章主要介绍了vue.js中for循环如何实现异步方法同步执行问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

vue.js中for循环实现异步方法同步执行

在项目中有些逻辑或者请求依赖另一个异步请求,常用的方法是回调函数、async  await 。

场景

For循环中异步接口查询返回数据

// 获取图片
        async getImg(data) {
            let glImgArr = data.split(';');
            this.imgData = [];
            console.log(glImgArr, 'glImgArr');
            var ary = [];
            glImgArr.forEach((v, index) => {
                const res = getLandImg({ id: v }).then(_res => {
                    if (_res.code == 200) {
                        return {
                            id: index + 1,
                            imgs: _res.data,
                        };
                    }
                    return '';
                });
                ary.push(res);
            });
            this.imgData = await Promise.all(ary);
        },

原理

async 是“异步”的简写,async 用于申明一个 function 是异步的,而 await 用于等待一个异步方法执行完成,并且await 只能出现在 async 函数中,否则会报错。

async作用:

  • 当调用一个 async 函数时,会返回一个 Promise 对象。当这个 async 函数返回一个值时,Promise 的 resolve 方法会负责传递这个值;当 async 函数抛出异常时,Promise 的 reject 方法也会传递这个异常值。
  • async 函数中可能会有 await 表达式,这会使 async 函数暂停执行,等待 Promise  的结果出来,然后恢复async函数的执行并返回解析值(resolved)。

await作用:

  • await 表达式会暂停当前 async function 的执行,等待 Promise 处理完成。若 Promise 正常处理(fulfilled),其回调的resolve函数参数作为 await 表达式的值,继续执行 async function。
  • 若 Promise 处理异常(rejected),await 表达式会把 Promise 的异常原因抛出。另外,如果 await 操作符后的表达式的值不是一个 Promise,则返回该值本身。

vue.js中循环语句的使用方法和相关技巧

概述

在Vue.js的开发中,循环语句是非常常用的语法之一。

通过循环语句,我们可以对数组和对象进行遍历,动态生成重复的HTML元素或执行一系列的操作。

v-for指令

v-for指令是Vue.js中最基本的循环语句指令,它用于遍历数组或对象,并根据每个元素生成对应的HTML元素或执行一段代码。

v-for指令的基本语法如下:

<div v-for="item in list" :key="item.id">{{ item.name }}</div>

在上述代码中,list是一个数组,item是数组中的每个元素。v-for指令会遍历数组中的每个元素,并根据每个元素生成一个

元素。使用:key指令可以为循环生成的每个元素设置唯一的标识符,这样可以提高性能和避免渲染错误。

v-for指令还支持获取当前元素的索引和父级元素的属性。

下面是一个示例:

<div v-for="(item, index) in list" :key="item.id">
  {{ index }} - {{ item.name }}
</div>

在上述代码中,index表示当前元素的索引,item表示当前元素的值。

v-for指令还支持在对象上循环,可以遍历对象的属性和值。

下面是一个示例:

<div v-for="(value, key) in object" :key="key">
  {{ key }}: {{ value }}
</div>

在上述代码中,key表示对象的属性名,value表示对象的属性值。

循环的嵌套

在Vue.js中,可以将循环语句进行嵌套,实现多层级的循环遍历。

例如,可以在一个循环内部再嵌套一个循环,实现二维数组的遍历。

下面是一个示例:

<div v-for="row in matrix" :key="row.id">
  <div v-for="cell in row" :key="cell.id">
    {{ cell.value }}
  </div>
</div>

在上述代码中,matrix是一个二维数组,row表示每一行,cell表示每个单元格。通过嵌套的循环语句,可以逐行逐个单元格地渲染二维数组中的值。

循环的过滤和排序

在使用v-for指令时,还可以对数组进行过滤和排序,从而根据一定的条件来筛选出需要的元素或调整元素的顺序。

下面是一个示例:

<div v-for="item in list.filter(item => item.price > 100)" :key="item.id">
  {{ item.name }} - {{ item.price }}
</div>

在上述代码中,filter()方法用于筛选出价格大于100的元素,并将符合条件的元素进行渲染。

<div v-for="item in sortedList" :key="item.id">
  {{ item.name }} - {{ item.price }}
</div>

在上述代码中,sortedList是一个经过排序的数组。通过对数组进行排序,可以调整元素的顺序,并根据排序后的结果进行渲染。

循环中的事件处理

在循环语句中,经常需要对生成的HTML元素绑定事件处理函数。例如,对于一个列表,可能需要为每个列表项添加点击事件。

在Vue.js中,可以使用循环的索引或唯一标识符作为参数传递给事件处理函数。

下面是一个示例:

<div v-for="(item, index) in list" :key="item.id" @click="handleItemClick(index)">
  {{ item.name }}
</div>

在上述代码中,handleItemClick()方法是一个事件处理函数,它接收索引作为参数,并根据索引执行相应的操作。

心得

循环语句是Vue.js中非常重要的一部分,它可以实现对数组和对象的遍历,动态生成重复的HTML元素或执行一系列的操作。

介绍了Vue.js中循环语句的使用方法和相关技巧,包括v-for指令的基本用法、循环的嵌套、循环的过滤和排序,以及循环中的事件处理。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Vue基础配置讲解

    Vue基础配置讲解

    在本篇文章里小编给大家整理的是关于Vue基础配置讲解内容,有兴趣的朋友们可以学习下。
    2019-11-11
  • vue3 axios安装及使用示例详解

    vue3 axios安装及使用示例详解

    这篇文章主要介绍了vue3 axios安装及使用示例代码,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-04-04
  • 详解vue-cli3使用

    详解vue-cli3使用

    这篇文章主要介绍了详解vue/cli 3使用,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-08-08
  • vue项目使用luckyexcel预览excel表格功能(心路历程)

    vue项目使用luckyexcel预览excel表格功能(心路历程)

    这篇文章主要介绍了vue项目使用luckyexcel预览excel表格,我总共尝试了2种方法预览excel,均可实现,还发现一种方法可以实现,需要后端配合,叫做KKfileview,本文给大家介绍的非常详细,需要的朋友可以参考下
    2023-10-10
  • vue实现吸壁悬浮球

    vue实现吸壁悬浮球

    这篇文章主要为大家详细介绍了vue实现吸壁悬浮球,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • antd table按表格里的日期去排序操作

    antd table按表格里的日期去排序操作

    这篇文章主要介绍了antd table按表格里的日期去排序操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • vue引入静态js文件的方法

    vue引入静态js文件的方法

    这篇文章主要介绍了vue引入静态js文件的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-06-06
  • 超详细图解如何运行vue项目

    超详细图解如何运行vue项目

    Vue是一套用于构建用户界面的渐进式框架,它的核心库只关注视图层,易于上手,也便于与其他库或已有项目整合,下面这篇文章主要给大家介绍了关于如何运行vue项目的相关资料,需要的朋友可以参考下
    2023-05-05
  • vue3 可拖动的左右面板分割组件实现

    vue3 可拖动的左右面板分割组件实现

    最近在使用vue的时候,遇到一个需求,实现左右div可通过中间部分拖拽调整宽度,本文就整理一下,分享给大家,有兴趣的可以学习
    2021-06-06
  • vue3 中使用 jsx 开发的详细过程

    vue3 中使用 jsx 开发的详细过程

    这篇文章主要介绍了vue3 中使用 jsx 开发,本文着重说一下在使用 .vue 文件和 .jsx 文件在使用语法上的差异,需要的朋友可以参考下
    2022-09-09

最新评论