js的promise用法

本文详细介绍了JavaScript中的Promise,它用于解决异步编程的问题。Promise构造函数接收一个函数,该函数有两个参数:resolve和reject。通过then方法可以指定异步操作成功或失败后的回调函数。文中通过加载图片和AJAX请求两个实例展示了Promise的使用,帮助读者深入理解其工作原理和应用场景。
摘要由CSDN通过智能技术生成

        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引擎提供,不用自己部署。

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

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

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

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

3,异步加载图片的例子

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>异步加载图片</title>
</head>

<body>
    <div id="box"></div>
    <script>
        box = document.getElementById('box');

        function loadImageAsync(url) {
            /*创建一个image资源对象,因为要网络请求,比较消耗时间***********************/
            function task(resolve, reject) {
                const image = new Image();
                image.src = url;
                //onload等于true
                image.onload = function() {
                    resolve(image);
                };
                //onerror等于false
                image.onerror = function() {
                    reject(new Error(' could not load image at ' + url));
                };

            }
            return new Promise(task);
        }

        promise = loadImageAsync('https://pan.baidu.com/box-static/disk-theme/theme/white/img/logo@2x.png');
        promise.then(
            function(data) {
                box.appendChild(data);
            },
            function(error) {
                box.innerHTML = '图片加载失败';
                console.log(error);
            }
        )
    </script>
</body>

</html>

4,Ajax实操

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>ajax实操</title>
</head>

<body>
    <div id="box"></div>
    <script>
        box = document.getElementById('box');

        function GETJSON(url) {
            /*************************************************************/
            function ajaxTask(resolve, reject) {
                const handler = function() {
                    if (this.readystate !== 4) {
                        return;
                    }
                    if (this.status === 200) {
                        resolve(this.response);
                    } else {
                        reject(new Error(this.statusText));
                    }
                };
                const client = new XMLHttpRequest();
                client.open("GET", url);
                client.onreadystatechange = handler;
                client.responseType = "json";
                client.setRequestHeader("Access-Control-Allow-Origin", "*");
                client.send();
            }
            /*************************************************************/
            return new Promise(ajaxTask);
        };
        /*************************************************************/
        promise = GETJSON("https://www.hupu.com/home/v1/news?pageNo=4&pageSize=50");//出现ajax无法跨域的问题,目前还不会解决

        promise.then(
            function(data) {
                console.log(data);;
            },
            function(error) {
                box.innerHTML = '加载失败';
                console.log(error);
            }
        )
    </script>

</body>

</html>
  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript中的Promise是一种用于处理异步操作的对象。它提供了一种更优雅和可读性更高的方式来编写和处理异步代码。 下面是Promise的基本用法: 1. 创建一个Promise对象: ```javascript const promise = new Promise((resolve, reject) => { // 异步操作的代码 }); ``` 2. 异步操作完成时调用resolve: ```javascript resolve(value); ``` 3. 异步操作失败时调用reject: ```javascript reject(error); ``` 4. 使用Promise的then方法处理成功的结果: ```javascript promise.then((result) => { // 处理成功的结果 }); ``` 5. 使用Promise的catch方法处理错误: ```javascript promise.catch((error) => { // 处理错误 }); ``` 6. 可以使用Promise的finally方法在Promise结束后执行一些操作: ```javascript promise.finally(() => { // 执行一些清理操作 }); ``` 下面是一个示例,演示如何使用Promise执行异步操作: ```javascript function fetchData() { return new Promise((resolve, reject) => { setTimeout(() => { const data = 'Some data'; // 模拟异步操作成功,调用resolve并传递数据 resolve(data); // 模拟异步操作失败,调用reject并传递错误信息 // reject('Error occurred'); }, 2000); }); } const promise = fetchData(); promise .then((data) => { console.log('Success:', data); }) .catch((error) => { console.log('Error:', error); }) .finally(() => { console.log('Cleanup'); }); ``` 在上面的示例中,我们创建了一个fetchData函数,它返回一个Promise对象。在Promise的构造函数中,我们模拟了一个异步操作(在这里使用了setTimeout),并根据操作的结果调用resolve或reject。 然后,我们通过调用then方法来处理成功的结果,并通过catch方法来处理错误。最后,我们使用finally方法来执行一些清理操作(无论Promise是成功还是失败)。 这就是Promise的基本用法。使用Promise可以更好地处理异步操作,避免了回调地狱,并提供了更清晰和可读性更高的代码结构。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值