• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

js的promise用法

武飞扬头像
谦虚且进步
帮助1

        js中的promise是一个异步编程的解决方案,语法层面上他是一个构造函数,名字为Promise()。

        他的作用就是将一个任务task封装为一个Promise类的实例对象,这个对象会将任务自动运行并得到任务结果,而且在得到结果的过程中并不会影响到其他任务的进行。由此实现多个任务的并发进行。

        实现异步的过程被隐藏在Promise类的实现过程中,我们只需要将任务交给Promise,Promise给我们一个instance,之后通过instance去拿任务结果就可以了。我们可以创建多个Promise类的实例instance。

        下面将介绍Promise用法的一般代码写法。

目录

1,Promise构造函数参数介绍

2,Promise实例对象的then()方法

3,异步加载图片的例子

4,Ajax实操


1,Promise构造函数参数介绍

        Promise构造函数接受一个函数作为参数,该函数的两个参数分别是resolve和reject。resolve和reject是两个函数,由JavaScript引擎提供,不用自己部署。

  1.  
    //resolve, reject名称不能修改
  2.  
    const promise = new Promise(function(resolve, reject) {
  3.  
    // ...some code
  4.  
    if ( /*异步操作成功,执行resolve方法,目的一般是将某些结果返回出去*/ ) {
  5.  
    resolve(value);
  6.  
    } else {
  7.  
    /*异步操作失败,执行reject方法,目的一般也是将某些结果返回出去*/
  8.  
    reject(error);
  9.  
    }
  10.  
    });

2,Promise实例对象的then()方法

        Promise 实例生成以后,可以用then方法分别指定resolved状态和rejected 状态的回调函数。也就是对返回的任务结果进行处理。

  1.  
    promise.then(resolved = function(value) {
  2.  
    // success,对返回的结果value进行处理
  3.  
    },
  4.  
    rejected = function(error) {
  5.  
    //failure,直接把错误类型报给用户
  6.  
    });

3,异步加载图片的例子

  1.  
    <!DOCTYPE html>
  2.  
    <html lang="en">
  3.  
     
  4.  
    <head>
  5.  
    <meta charset="UTF-8">
  6.  
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
  7.  
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
  8.  
    <title>异步加载图片</title>
  9.  
    </head>
  10.  
     
  11.  
    <body>
  12.  
    <div id="box"></div>
  13.  
    <script>
  14.  
    box = document.getElementById('box');
  15.  
     
  16.  
    function loadImageAsync(url) {
  17.  
    /*创建一个image资源对象,因为要网络请求,比较消耗时间***********************/
  18.  
    function task(resolve, reject) {
  19.  
    const image = new Image();
  20.  
    image.src = url;
  21.  
    //onload等于true
  22.  
    image.onload = function() {
  23.  
    resolve(image);
  24.  
    };
  25.  
    //onerror等于false
  26.  
    image.onerror = function() {
  27.  
    reject(new Error(' could not load image at ' url));
  28.  
    };
  29.  
     
  30.  
    }
  31.  
    return new Promise(task);
  32.  
    }
  33.  
     
  34.  
    promise = loadImageAsync('https://pan.百度.com/box-static/disk-theme/theme/white/img/logo@2x.png');
  35.  
    promise.then(
  36.  
    function(data) {
  37.  
    box.appendChild(data);
  38.  
    },
  39.  
    function(error) {
  40.  
    box.innerHTML = '图片加载失败';
  41.  
    console.log(error);
  42.  
    }
  43.  
    )
  44.  
    </script>
  45.  
    </body>
  46.  
     
  47.  
    </html>
学新通

4,Ajax实操

  1.  
    <!DOCTYPE html>
  2.  
    <html lang="en">
  3.  
     
  4.  
    <head>
  5.  
    <meta charset="UTF-8">
  6.  
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
  7.  
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
  8.  
    <title>ajax实操</title>
  9.  
    </head>
  10.  
     
  11.  
    <body>
  12.  
    <div id="box"></div>
  13.  
    <script>
  14.  
    box = document.getElementById('box');
  15.  
     
  16.  
    function GETJSON(url) {
  17.  
    /*************************************************************/
  18.  
    function ajaxTask(resolve, reject) {
  19.  
    const handler = function() {
  20.  
    if (this.readystate !== 4) {
  21.  
    return;
  22.  
    }
  23.  
    if (this.status === 200) {
  24.  
    resolve(this.response);
  25.  
    } else {
  26.  
    reject(new Error(this.statusText));
  27.  
    }
  28.  
    };
  29.  
    const client = new XMLHttpRequest();
  30.  
    client.open("GET", url);
  31.  
    client.onreadystatechange = handler;
  32.  
    client.responseType = "json";
  33.  
    client.setRequestHeader("Access-Control-Allow-Origin", "*");
  34.  
    client.send();
  35.  
    }
  36.  
    /*************************************************************/
  37.  
    return new Promise(ajaxTask);
  38.  
    };
  39.  
    /*************************************************************/
  40.  
    promise = GETJSON("https://www.hupu.com/home/v1/news?pageNo=4&pageSize=50");//出现ajax无法跨域的问题,目前还不会解决
  41.  
     
  42.  
    promise.then(
  43.  
    function(data) {
  44.  
    console.log(data);;
  45.  
    },
  46.  
    function(error) {
  47.  
    box.innerHTML = '加载失败';
  48.  
    console.log(error);
  49.  
    }
  50.  
    )
  51.  
    </script>
  52.  
     
  53.  
    </body>
  54.  
     
  55.  
    </html>
学新通

这篇好文章是转载于:编程之路

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 编程之路
  • 本文地址: /boutique/detail/tanhghafaf
系列文章
更多 icon
同类精品
更多 icon
继续加载