promise的学习心得记录

这里只讲promise,和async的使用方法,不会讲他们的原理。

Promise 是异步编程的一种解决方案,可以用于取代传统的回调函数,该变那些函数层层嵌套调用的尴尬局面。

1)promise

基本语法:

var p= new Promise(function(resolve,reject){
  if(....) resolve();
       else reject(.....);
});

p.then(function(){//resolve
  .......
}).catch(function(){//reject
  .........
});

基本意思就是:每一个promise都有两种状态(对应着请求的pending->fulfiled,pending---->rejected)

pending->fulfiled:表示成功,执行then()的第一个回调函数

pending-->rejected失败,执行then()的第二个回调函数,一般我们更习惯用catch();更周全

demo01:使用vue,axios,promise演示一下promise到底是啥???

首先在组件中定义了一个getList()

getList(){
     const self=this;
     let promise=new Promise(function(resolve,reject){
                    /*
                    resolve((function(){
                         axios.get(‘./dataAction.php‘).then(function(res){
                          self.list=res.data;

                        }).catch(function(error){});
                        return self.list
                    })());
                    */
          axios.get(‘./dataAction.php‘).then(function(res){
         self.list=res.data;
         resolve(res.data);
        }).catch(function(error){});

     });

promise.then(function(res){
      console.log("我要等待axios请求之后再执行");
      console.log(res);
     }).then(function(){
});

 

在组件挂在之后就会触发这个方法,

mounted(){
  this.getList();
  //this.countMethod();
}

为了演示出效果我在php代码中做了延时处理:(目的是为了延时四秒之后返回结果,这样前端就是一个漫长的等待过程)

<?php
     $dsn="mysql:dbname=vue;host=127.0.0.1";
    $user="root";
    $password=‘‘;
    $db= new PDO($dsn,$user,$password);
    $sta= $db->prepare("select * from res");
     $sta->execute();
     $arr=array();
     while($row=$sta->fetch(PDO::FETCH_ASSOC)){
         //print_r($row);

         $arr[]=$row;
     }
     $interval=4;
      sleep($interval);
     print_r( json_encode($arr));
?>

你会发现确实过了四秒中上面那两句红色的才执行。。。。。。。。

既然现在框架ajax一般都有的自己promise,那我们何必要学习了??

现在我的需求是,有三个很普通函数,不涉及到请求,这三个函数都有一个延迟函数settimeout,返回一个数字,另外还有一个函数用于接受他们的返回参数,进行相加,返回结果??

按照我们的理解settimeout会在主程序执行完之后才执行,这样我们根本就不能获得相加的结果

demo02:

function mycount1(){
      let a=4;
      setTimeout(()=>{ return a;},1000);               //resolve(a);           },function mycount2(){
       let b=6;
       setTimeout(()=>{resolve(b);                  },5000);
 },
 function countAll(a,b){  return a+b; }
 var    a=mycount1(); var    b=mycount2(); countAll(a,b);    

现在我们有了promise,那么这一切就好说了

因为有多个执行过程,这个时候我想到了promise.all([......]).then();

语法作用就是all([.....])中可以有多个promise对象,等他们都执行成功之后才会触发后面的then(),,[前提是都执行成功之后]


function mycount1(){
  return new Promise(function(resolve,reject){
  let a=4;
  setTimeout(()=>{resolve(a)},1000);
  //resolve(a);
});

  /*
    return Promise.resolve((function(){
    setTimeout(()=>{return 4},4000);

    })())
  */
};

function mycount2(){
  let b=6;
  return new Promise(function(resolve,reject){
  setTimeout(()=>{resolve(b);},5000); });
};

function countAll(a,b){
  console.log("我是最后执行的");
  console.log(a+b);
};

const m1=mycount1().then((a)=>{console.log(a); return a;});
const m2=mycount2().then((b)=>{console.log(b); return b;});

//此时m1,m2都是promise对象
Promise.all([m1,m2]).then(function([a,b]){
  countAll(a,b);
});

这里在给一个promise.all([])的例子

    getList3(){
      const self=this;
      const a1=axios.get(‘./dataAction.php‘);//axios请求之后返回一个promise
      const a2=axios.get(‘./dataAction.php‘);//axios请求之后返回一个promise
                //两个promise返回两个参数,因此我们就用数组接受参数(如果只用一个参数接受,他会自动变成一个数组)
                //首先promise.all的参数是promise数组集合
      Promise.all([a1,a2])
             .then(([r1,r2]) => {
               console.log(r1);
            //    let arr=[];
           //arr.push(...r1);
            console.log(r2);
     }); },

mounted(){
  //this.getList();
  //this.countMethod();
  this.getList3();
}


讲了这么多不是为了好玩,在项目中我们是不是有很多情况下,是需要在某一个函数执行完之后再执行另一个函数的,

例如页面的加载完之后,或者dom树加载完之后,当然学过js的同学知道,页面加载有一个document.readyState的几个状态

https://developer.mozilla.org/zh-CN/docs/Web/API/Document/readyState

然后就有了我们经常用的

1)网站所有的资源都加载完毕才执行

window.onload=function(){};

2)dom树加载完之后执行,先于window.onload;

$(function(){});//或者$(document).ready(function(){......});

当然promise还有其他的api,你可以google自己学习下,

例如:Promise.resolve(.....)可以将一个非promise对象包装成一个promise,这样就可以使用then方法了

时间: 2024-12-21 08:57:26

promise的学习心得记录的相关文章

【学习记录】关于makefile而进行的互联网学习技巧练习及学习笔记和学习心得记录(vs2010)

我也不知道作为一个完全的windows平台下的不怎么专业的软件工程学生,看到<Accelerated C++>的源代码,第一反应是:哦!我应该用make生成工程文件.然后我愉快的用AOL开始搜索相关资料. 然并卵!我一定是被什么奇怪的生物附身了.我应该直接用vs创建项目->导入文件.然后……ctrl+F5.多么完美. 可是……以下: [教程]来自于云风大大的blog(云风的 BLOG) IDE 不是程序员的唯一选择(一) 以及后面的(二)(三)(四) 以及大大写了一篇半,只为了说明用cl

学习心得记录:[一]sql安装与配置

时间:2015年9月13日 02:43:09 科目:mysql的安装 笔记: 准备: 1.首先下载解压版的mysql 2.将下载好的文件放到c:\Program Files\MYSQL下(mysql文件夹为新建) 3.将path的环境变量设置为bin的文件目录 配置: 进入mysql文件夹内找到my-defaul.ini的文件,或者自己建立一个my.ini的文件 修改bin的位置和数据存放data的位置 [mysqld] basedir=C:\Program Files\MySQL\MySQL 

弦子博客学习心得记录

一.多张线程与界面处理 1.子线程千万不要访问主线程的UI,(memo,Label),我发现这样做的程序员很多,在diocp中经常会用到onConnected/OnDisconnected事件中直接操作主窗体的Memo.导致程序无法正常退出,或者出现卡死主界面的情况,原因我想可以归纳到访问冲突上面,用临界也不能解决问题.很多组件都是靠windows消息驱动,他才不会使用零件去处理消息,所以临界也没办法.你只有老老实实的投递到主线程去完成这部分工作,qworker和iocpTask都可以很好的完成

我的MYSQL学习心得(八)

我的MYSQL学习心得(八) 我的MYSQL学习心得(一) 我的MYSQL学习心得(二) 我的MYSQL学习心得(三) 我的MYSQL学习心得(四) 我的MYSQL学习心得(五) 我的MYSQL学习心得(六) 我的MYSQL学习心得(七) 这一篇<我的MYSQL学习心得(七)>将会讲解MYSQL的插入.更新和删除语句 同样的,只会讲解跟SQLSERVER不同的地方 插入 将多行查询结果插入到表中 语法 INSERT INTO table_name1(column_list1) SELECT (

在马哥linux运维学院学习心得

题目:在马哥linux运维学院学习心得 姓名:谭龙 班级:M18 学号:26 时间:2016-02-29--2016-06-02(正常毕业时间预计在7月中上旬)   正文: 个人基本情况: 我是一名在校的即将毕业的大四学生,毕业时间为2016.7.专业为矿物加工工程专业,纯正的四川-广安人(邓小平故居就在那).因找不到工作,加上自己也不知道干什么,在堂弟的推荐下,来参加了马哥linux运维学院的学习:怀揣着一颗对计算机懵懂的心,开始涉足从未接触过了linux. 个人收获与心理变化: 在一开始接触

第一篇大数据学习心得

之前未习惯发布学习心德博文,后续会采用这种方式发布学习心得,希望能够很好的督促自己. 计划会按scala,Hadoop,Spark的顺序去学习. 刚学scala的时候,眼前一亮,这语法跟python,java很像啊,刚好两者很熟悉,偷笑,后面果然学的得心应手.今天就不发表具体的技术内容.反正王学林老师的视屏讲解很好,声音非常富有感染力,想开小差都比较难,呵呵,话语精炼,个人较喜欢的风格,这里说下这段时间学习scala的小心得?,视频学完一章紧接着进行敲代码,调试,最后记笔记,对,记笔记,不一定是

C++用法的学习心得

c++这门课,在我刚进入大学的就已经开始接触了.因为自己的专业就是计算机科学,因此c++嘛,对于我来说还是比较重要的.不同于其他专业,一开始我接触就是c++了,跳过了c语言一类的课.就我自己认为,c++这课学起来还是很有难度的.大一上课的时候,老师就说过这课在生活中的应用很广泛.处于初学者的我,开始给我的感觉就是很是乏味枯燥,提不起兴趣.不过仔细想想自己的专业就是和它有关,就算将来自己不从事这个行业,还是很有学习它的必要.因为多一门技术总归是不会吃亏的. 作为男生嘛,自己没有少玩游戏.很多人玩游

小小六的前端学习心得

打算写这篇文章已经好久了,但是文采不行,不知道如何下笔,今天终于鼓起勇气用我拙劣的作文水平来讲述一下这段时间我学习前端开发的心得. 先从我的专业说起.我本人是学计算机的.全名是叫计算机科学与技术(软件方向),学校虽然是一个211学校,学习成绩也还行,但是对于编程这一块,真的是很弱很弱.所以我对计算机编程真正的学习是从实习这段时间开始的.说到这里,我必须得感谢带我进入前端的学长.因为他我才能在今天坐在这里写这篇学习心得. 所以,首先最好是有一个愿意耐心的指导你学习的人,也就是一个好的师傅.他能根据

我的MYSQL学习心得(十) 自定义存储过程和函数

我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(五) 运算符 我的MYSQL学习心得(六) 函数 我的MYSQL学习心得(七) 查询 我的MYSQL学习心得(八) 插入 更新 删除 我的MYSQL学习心得(九) 索引 我的MYSQL学习心得(十一) 视图 我的MYSQL学习心得(十二) 触发器 我的MYSQL学习心得(十三) 权限管理 我的MYSQL学习