有点经验的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. HibernateUtil.java

    package com.hkwy.util; import org.hibernate.Session; import org.hibernate.SessionFactory; import org ...

  2. bodyparser

    今天在用bodyparser时,遇到了如下问题: 首先科普下bodyparser的作用:它用于解析客户端请求的body中的内容,内部使用JSON编码处理,url编码处理以及对于文件的上传处理. 现在继 ...

  3. CSS代码规范

    空格 选择器 与 { 之间必须包含空格. 列表型属性值 书写在单行时,, 后必须跟一个空格. 属性名 与之后的 : 之间不允许包含空格, : 与 属性值 之间必须包含空格. margin: 0; .+ ...

  4. 总结js常用函数和常用技巧(持续更新)

    学习和工作的过程中总结的干货,包括常用函数.常用js技巧.常用正则表达式.git笔记等.为刚接触前端的童鞋们提供一个简单的查询的途径,也以此来缅怀我的前端学习之路. PS:此文档,我会持续更新. Aj ...

  5. Spring in Action 学习笔记二-DI

    装配bean 2015年10月9日 9:49             Sprng中,对象无需自己负责查找或创建其关联的其他对象.相关,容器负责吧需要相互协作的对象引用赋予各个对象. 创建应用对象之间协 ...

  6. Atitit 衡量项目的规模

    Atitit 衡量项目的规模 1. 预估衡量项目的规模的方法1 1.1. 方法一.Delphi 法1 1.2. 方法二. 类比法1 1.3. 方法三.功能点估计法1 1.4. 方法四.PERT估计法2 ...

  7. app使用微信支付成功后,点击返回到该app却跳到另外一个app去了

    刚接手了公司iOS的两个APP, 现在碰到了这样一个问题: 有一台iPhone在一个APP中使用了微信支付,支付成功后,点击返回到该APP,结果却跳到了另外一个APP去了. 这两个APP都是公司开发的 ...

  8. Activity生命周期

    在开始之前我们先了解一下什么是Activity: 直接翻译为:"活动",而在Android中更多的是代表手机的屏幕,是Android的四大组件之一,重要的组成单元,提供了与用户交互 ...

  9. 菜单(Menu)的三中创建方式——Android开发之路2

    菜单的三种创建方式 一.OptionsMenu---选项菜单 Android应用中的菜单默认是隐藏的,只有当用户点击手机上的MENU键,系统才会显示菜单.这种菜单叫做选项菜单(Options Menu ...

  10. Play Framework 项目遇到问题

    1.Debug调试出错,提示: Error occurred during initialization of VMagent library failed to init: jdwpERROR: C ...