首页 > 其他分享 >vue中同步方法的实现

vue中同步方法的实现

时间:2023-10-17 17:02:31浏览次数:48  
标签:异步 同步 resolve 任务 vue Promise reject new 方法

这篇文章主要介绍了vue中同步方法的实现,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

目录

  • vue同步方法实现
  • 有三种实现方式
  • vue中的同步和异步问题
  • 同步
  • 异步
  • 总结


vue同步方法实现


有三种实现方式

1、axios本身属于Promise

利用函数式的then获取请求返回结果,也是最常用的,如下:

request({
        url: '/test/XXX/XXXX',
        method: 'post',
        data: param
      }).then(ret => {
        if (ret.code === RESULT_CODE.SUCCESS) {
          this.$message.success('保存成功')
        }
      })

此处request对象是对axios做了一层封装,不用在意。此种方式的缺陷是:只能用于请求返回后只有简单操作的情形。

如果返回后的操作比较多,代码就会显得臃肿,可读性差,还有一种情况,即该请求被调用的情况,由于axios没有配置为同步请求的配置项,因此无法直接将上述代码封装后直接调用,因此,引申出第二种方法:

2、async结合await

// api.js文件
// test1方法作为被调用方,被test1方法调用
export async function test1 (param) {
    // 返回一个Promise对象,真正需要返回给调用方的数据,放在resolve中
    return new Promise(resolve => {
        // request对象是对axios的封装,不用在意
        request({
            url: '/emr/order/deleteOrder',
            method: 'post',
            data: order
        }).then(ret => {
           resolve(ret.data)
        }
      })
    })
}
// VUE文件
methods: {
    // test2作为调用方调用test1方法
    async test2 (param) {
        const data = await test1(param)
    }
}

3、引入jquery

此处就不写了,这种方式感觉挺没追求的。


vue中的同步和异步问题


同步

在主线程上排队之行的任务,只有在最前面的任务执行完成之后,才之行后面的任务。

(生活中的例子话糙理不怪:银行排队,只有一个窗口的时候,A业务办理完在接着办理B)


异步

是指不进入主线程,而是进入了“任务队列”的任务,只有“任务队列”通知主线程,某个异步任务可执行了,该任务才会进入主线程执行。

(生活中的例子话糙理不怪:多个窗口,可以同时办理业务,互不影响) 

  • 同步的优点是:同步是按照顺序一个一个来,不会乱掉,更不会出现上面代码没有执行完就执行下面的代码,
  • 缺点:是解析的速度没有异步的快;
  • 异步的优点是:异步是接取一个任务,直接给后台,在接下一个任务,一直一直这样,谁的先读取完先执行谁的,
  • 缺点:没有顺序 ,谁先读取完先执行谁的 ,会出现上面的代码还没出来下面的就已经出来了,会报错;

异步任务分为:宏任务   微任务

  • 宏任务:包含整体代码script /  setTimeout /  setInterval
  • 微任务:Promise.then(非new Promise) / process.nextTick(node中)

事件执行顺序:

  • 1.先执行宏任务,在执行微任务
  • 2.微任务根据先进先出的顺序执行
  • 3.微任务清空后在执行宏任务
  • 4.按先进先出的顺序取出执行

Promise 实现异步调用

asnyc/await 实现同步调用

// 项目中使用的事例:Vue接口请求异步变同步
 created() {
     this.initData();
 }
 methods: {
     async initData() {
         let res = await getList(this.params);
         if (res.message === "成功") {
             this.resultList = res.data;;
         }
     }
 }
// 异步请求同步的方法
    handleClick() {
        return new Promise((resolve,reject) => {   //resolve 成功 ,reject 失败
            getRequest().then(res => {
                //操作1
                resolve();
            }).catch(error =>{
                console.log(error)
                reject()
            })
        })
    },
    test(){
        Promise.all([this.handleClick()]).then(res=>{
            //操作2
        })
    }
// promise的操作
const promise = new Promise(function(resolve, reject){
    if(一步操作成功){
        resolve(value);
    }else{
        reject(error);
    }
})
// 异步操作
new Promise((resolve, reject) => {
    resolve(1);
    console.log(2);
}).then(r => {
    console.log(r);
});
// 2
// 写法一
const promise = new Promise(function(resolve, reject) {
    try {
        throw new Error('test');
    } catch(e) {
        reject(e);
    }
});
promise.catch(function(error) {
    console.log(error);
});
// 写法二
const promise = new Promise(function(resolve, reject) {
    reject(new Error('test'));
});
promise.catch(function(error) {
    console.log(error);
});

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持51博客。

标签:异步,同步,resolve,任务,vue,Promise,reject,new,方法
From: https://blog.51cto.com/u_16307590/7907803

相关文章

  • 10月17日__new__方法学习以及__call__和__init__的关系
    目录__new__方法以老板和员工为例:老板(Boss)可以雇佣员工(实例对象)定义了雇佣员工的方式(__new__)这个方法决定是否找新的员工,如果招了新的员工,这个员工入职后需要进行初始化的安排所属部门以及工作(__init__).总结在元类里__call__和__new__和__in......
  • 向量召回:深入评估离线体系,探索优质召回方法
    向量召回:深入评估离线体系,探索优质召回方法1.简介近年来,基于向量进行召回的做法在搜索和推荐领域都得到了比较广泛的应用,并且在学术界发表的论文中,基于向量的denseretrieve的方法也在不少数据集上都战胜了sparseretrieve,吸引了越来越多的关注。在内网的不少文章中也都介绍......
  • 文献汇总---降尺度方法在气候研究中的应用
    地球系统模式(Earthsystemmodels,ESM)是预测未来气候变化的主要途径,其运行结果是气候谈判和决策的重要依赖。但运行这些模式既困难又昂贵,所研究的情景也很有限。因此需要一种快速、准确的地球系统模式的仿真,将低分辨率的平均响应转化为高分辨率的区域气候变化变量,进而开展人类与......
  • Chrome浏览器复制Cookie的方法
    打开需要复制的页面,按F12打开开发者工具,如图操作  ......
  • vue2使用 tinymce富文本编辑器-图片上传、粘贴图片上传致服务器
    1.安装tinymce富文本编辑器插件npmitinymcenpmi@tinymce/tinymce-vue2.创建Editor.js文件封装组件以便使用<template><divclass="tinymce-editor"><editorv-model="myValue":init="init":disabled="disabled&qu......
  • 聊聊基于Alink库的特征工程方法
    示例代码及相关内容来源于《Alink权威指南(Java版)》独热编码OneHotEncoder是用于将类别型特征转换为独热编码的类。独热编码是一种常用的特征编码方式,特别适用于处理类别型特征,将其转换为数值型特征。对于每个类别型特征,OneHotEncoder将其编码成一个长度为类别数量的向量。......
  • vue学习3 npm创建项目
    创建项目安装最新node.js最新稳定版本创建项目文件加,在文件即下cmd输入命令npmcreatevite@latestfirstweb或者npminitvite@latestfirstweb然后选择vue。然后选择typecript/JavaScript,然后在文件夹下就创建好了项目文件  使用vscode打开该目录输入命令npmi......
  • 0到1搭建vue2.0项目
    一、创建vue项目1、node-v查看是否安装了node 如果没安装,到官网下载安装https://nodejs.org/en2、创建名为VueProject的文件夹,cmd进入该文件夹,npminit-y 进行初始化(备注:在使用命令行工具npm进行初始化项目时,-y是一个参数,表示在初始化过程中自动应答所有的问题为默......
  • 如何实现电压监控的四种方法
    [导读]为什么监控电压很重要?我们知道监控电压轨可以帮助我们防止掉电、检测过压事件、测量电池电量并帮助我们实施整体诊断策略。本文将介绍如何实施电压监控。有四种关键方法:为什么监控电压很重要?我们知道监控电压轨可以帮助我们防止掉电、检测过压事件、测量电池电量并帮助我......
  • Vue中 三个点 ... 的用法
    Vue中三个点...的用法主要是操作数组和对象一、操作数组//1.把数组中的元素孤立起来letiArray=['1','2','3'];console.log(...iArray);//打印结果123//2.在数组中添加元素letiArray=['1','2','3'];console.log(['0&......