有点经验的js前端都知道  ajax异步函数里面的结果不会立即返回,如果你想在一个异步函数得到某个结果后去执行一个语句怎么做?

if ( 异步函数 ) { 语句 }  可能很多人都踩过这样坑,这个时候新手一般都找不到问题,左看右看上看下看都是绝对完美的,找不到任何错误;

懂得人就会 把 这句话 放到异步里面去;这样做就没有问题了;但是如果异步里面判断结果后又要做一个异步,里面继续嵌套几个异步......这种情况是常见的;

所以其实 promise 就是以一种优雅的方式来解决这个问题;

提前说明一下,接下来的第一个代码片段是我们自己实现的简易版 Promise ,然后第二个代码片段使用了一下我们自己实现的简易版 Promise ;

让读者更清晰的理解 Promise 的设计原理,第三个代码片段就是使用js 自带的 Promise 做个演示;

 var Promise = function() {
     this.callbacks = [];
 }
 Promise.prototype = {

     resolve: function(result) {
         this.complete("resolve", result);
     },

     reject: function(result) {
         this.complete("reject", result);
     },

     complete: function(type, result) {
             while (this.callbacks[0]) {
             this.callbacks.shift()[type](result);
         }
     },

     then: function(successHandler, failedHandler) {
         this.callbacks.push({
             resolve: successHandler,
             reject: failedHandler
         });

         return this;
     }
 }

一个简单的Promise架子就准备好了,下面的来体验一把;

 // 实例化一个 Promise 对象
 var promise = new Promise();

 // 这个函数是一个异步(结果不是马上返回的)函数,可以用ajax代替setTimeout部分

 var delay = function() {
     setTimeout(function() {
         // do something ...
         // 在异步体内发射一个成功或失败的信号,就会对应then里面成功或失败的处理函数
         // 比如这里我们发射处理成功信号到 promise 里面
         promise.resolve('处理成功');
         // promise.reject('处理失败');
     }, 1000);
     // 返回 promise
     return promise;
 };

 // 这个函数用来处理成功信号
 var callback1 = function(re) {
     // do something ...
     alert(re);
 };
 // 这个函数用来处理失败信号
 var callback2 = function(re) {
     // do something ...
     alert(re);
 };
 // then里面传了两个函数,但是最终只会调用一个函数,根据成功或失败的信号来决定调用那个
 // delay里面发射的成功信号就调用 callback1 否则调用 callback2
 delay().then(callback1,callback2);

 // 看上面架子可以知道 promise 对象最后是 return this ;也就是返回的也是 promise
 // 可以实现链式操作  ,比如  delay().then(callback1,callback2).then(callback1,callback2);

js自带的Promise 用法完全一样;

 function loadMusic(url) {

     // Promise 的参数是一个函数  而这个函数里面包含两个参数  这两个参数实际上就是 Promise对象的方法
     // 注意 下面调用 Promise 对象的 then 方法传的两个函数作为参数 两者是对应的
     return new Promise(function(resolve, reject) {

         var audio = new Audio();
         audio.src = url;
         //  当你插入一个audio标签的时候,浏览器要联网加载,根据网络好坏加载到数据的时间就不同
         //  所以这个过程就是异步的,当加载到一定数据能够播放后就会触发这个事件,
         audio.addEventListener('canplay', function() {
             resolve(audio);
         });
         //  比如歌曲地址错误 无法加载到音频  触发这个事件
         audio.addEventListener('error', function(){
             reject("not found!");
         });

     });
 }

 loadMusic('/path/music.mp3').then(function(audio) {

     audio.play();

 }, function(notify) {

     alert(notify);
 });

javascript 中 Promise的使用的更多相关文章

  1. 全面理解Javascript中Promise

    全面理解Javascript中Promise 最近在学习Promise的时候,在网上收集了一些资料,发现很多的知识点不够系统,所以小编特意为大家整理了一些自认为 比较好的文章,供大家更好地学习js中非 ...

  2. JavaScript中 Promise的学习以及使用

    今天一个哥们发过来一段js代码,没看懂,就顺便学习了一下,代码如下  Promise.resolve('zhangkai').then(value => {console.log(value)} ...

  3. 浅谈Javascript中Promise对象的实现

    https://segmentfault.com/a/1190000000684654 What? Promise是CommonJS的规范之一,拥有resolve.reject.done.fail.t ...

  4. Javascript中Promise的简单使用

    // 函数功能:1秒以后创建一个10以内的随机整数,并判断这个数是否为偶数:如果是偶数则做一件事情,如果是奇数则做另一件事情 function doSomthing() { var promise = ...

  5. JavaScript中Promise 使用、原理以及实现过程

    1.什么是 Promise promise 是目前 JS 异步编程的主流解决方案,遵循 Promises/A+ 方案. 2.Promise 原理简析 (1)promise 本身相当于一个状态机,拥有三 ...

  6. Javascript中Promise对象的实现

    http://segmentfault.com/a/1190000000684654 http://www.infoq.com/cn/news/2011/09/js-promise/

  7. 通过一道笔试题浅谈javascript中的promise对象

    因为前几天做了一个promise对象捕获错误的面试题目,所以这几天又重温了一下promise对象.现在借这道题来分享下一些很基础的知识点. 下面是一个面试题目,三个promise对象捕获错误的例子,返 ...

  8. javascript中的promise和deferred:实践(二)

    javascript中的promise和deferred:实践(二) 介绍: 在第一节呢,我花了大量的时间来介绍promises和deferreds的理论.现在呢,我们来看看jquery中的promi ...

  9. JavaScript中的Promise【期约】[未完成]

    JavaScript中的Promise[期约] 期约主要有两大用途 首先是抽象地表示一个异步操作.期约的状态代表期约是否完成. 比如,假设期约要向服务器发送一个 HTTP 请求.请求返回 200~29 ...

随机推荐

  1. cin.ignore()函数的用法

    cin.ignore(a,ch)方法是从输入流(cin)中提取字符,提取的字符被忽略(ignore),不被使用.每抛弃一个字符,它都要计数和比较字符:如果计数值达到a或者被抛弃的字符是ch,则cin. ...

  2. JDBC_part4_大对象_DAO_Bean_DButi

    本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 谢谢配合! JDBCday04_大对象_Dao_DBUtil_Ja ...

  3. 301和302 Http状态有啥区别?

    301和302 Http状态有啥区别? 301,302 都是HTTP状态的编码,都代表着某个URL发生了转移,不同之处在于: 301 redirect: 301 代表永久性转移(Permanently ...

  4. 改变你代码习惯的ES6

    最近读阮一峰老师的ES6标准入门,让我感觉到了ES6的强大之处,读书之余整理了一些笔记,因为边读边记录的,所以可能会比较杂乱. ECMAScript和Javascript的关系 1996年11月,Ja ...

  5. Andriod 自定义控件之音频条

    今天我们实现一个直接继承于View的全新控件.大家都知道音乐播放器吧,在点击一首歌进行播放时,通常会有一块区域用于显示音频条,我们今天就来学习下,播放器音频条的实现. 首先我们还是先定义一个类,直接继 ...

  6. Android 手机卫士--9patch图

    本文主要介绍9patch图 *.9.png:android手机上,可以按需求自动拉伸的图片 本文地址:http://www.cnblogs.com/wuyudong/p/5947195.html,转载 ...

  7. Android中的AlertDialog使用示例五(自定义对话框)

    在Android开发中,我们经常会需要在Android界面上弹出一些对话框,比如询问用户或者让用户选择.这些功能我们叫它Android Dialog对话框,AlertDialog实现方法为建造者模式. ...

  8. MySQL:procedure, function, cursor,handler

    Procedure & Function Procedure 语法: CREATE [DEFINER = { user | CURRENT_USER }] PROCEDURE sp_name ...

  9. shell 脚本之 shell 练习题汇总

    整理了一些 shell 相关的练习题,记录到这里. 1. 请按照这样的日期格式 xxxx-xx-xx 每日生成一个文件,例如:今天生成的文件为 2013-09-23.log, 并且把磁盘的使用情况写到 ...

  10. SCNU 2015ACM新生赛初赛【1007. ZLM的扑克牌】解题报告

            题目链接详见SCNU 2015新生网络赛 1007. ZLM的扑克牌 .         其实我在想这题的时候,还想过要不要设置求最小的排列,并且对于回文数字的话,可以把扑克牌折起来( ...