首页 web前端 js教程 如何使用JavaScript中的promise对象

如何使用JavaScript中的promise对象

Dec 11, 2018 pm 04:38 PM
promise对象

JavaScript中promise是一个对象,表示异步处理的最终完成或失败,使用promise可以很容易的进行异步处理,promise对象还可以明确异步执行成功和失败时的过程,因此可以消除问题的原因。

promise对象

promise对象也可以执行并发异步处理,换句话说,可以按顺序执行多个异步处理,并在下一个处理中使用先前处理的结果。

JavaScript按顺序执行命令语句

例如,下面有三种函数,如果处理被sample2函数延迟,则不处理sample3函数。

顺序执行的JavaScript程序的示例

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<title></title>

</head>

<body>

<script>

var result = "正确。";

var doSomething1 = function() {

  console.log('处理没有出现问题1' + result);

};

var doSomething2 = function() {

  console.log('出现错误 ' + result2);

};

var doSomething3 = function() {

  console.log('处理没有出现问题 3' + result);

};

doSomething1();

doSomething2();

doSomething3();

</script>

</body>

</html>

登录后复制

运行结果如下所示

promise对象

JavaScript回调函数

与此相对应的,

与此相反,有些方法不会读入页面然后按顺序处理。

比如,读到页面后,过了5秒就可以执行了。

当页面加载并完成其他处理时,将在5秒后执行此操作。

页面读取5秒后执行的程序

代码如下

1

2

3

4

5

6

7

8

9

10

11

12

13

14

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<title></title>

</head>

<body>

<script>

setTimeout(function() {

  alert('刚刚过去了5秒!');

}, 5000)

</script>

</body>

</html>

登录后复制

效果如下:5秒后将会显示如下页面

promise对象

这样,在完成某个进程后,回调相应的函数被称为回调,此外,这种功能称为回调功能。

回调函数与promise

如果有回调函数的话,则无法使用回调函数轻松解决异步处理等问题。

这是因为使用回调函数创建复杂的异步处理会导致代码非常复杂。

此外,回调函数用于接收异步执行的结果,其规范取决于每个库。

出现在那里的是“promise”。

通过使用promise,可以更简单地创建异步处理,并且也可以统一规范的接收结果。

使用环境

由于某些浏览器与promise不兼容,因此最好事先检查您的环境中是否有能够支持使用的浏览器。

promise的作用

1.使用promise,可以保证在当前正在处理的JavaScript事件循环执行完成之前不会被调用。这使得能够实际地进行考虑顺序的处理。

2.使用promise,如果异步处理虽然完成但是失败后,利用.then注册回调也可以保证操作。换句话说,在完成当前正在处理的JavaScript事件循环的执行之前,不会进行调用。

3.使用.promise,.then可以多次实现。换句话说,保证可以按添加顺序独立地执行多个回调函数。

接下来我们就来看一下 promise的使用方法

使用以下语法描述Promise。

1

new Promise( function(resolve, reject) { ... } );

登录后复制

执行的顺序是

1

function(resolve, reject) { ... }

登录后复制

已被执行

1

new Promise

登录后复制

将被执行

1

function(resolve, reject)

登录后复制

处理成功时执行Resolve,处理失败时执行reject。

我们来看一个具体的示例

像回调函数一样,我们将在5秒后创建一个要处理的程序。

代码如下

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<title></title>

</head>

<body>

<script>

function hidouki() {

    return new Promise(function (resolve, reject) {

        setTimeout(function () {

            resolve('异步执行成功');

        }, 5000);

    });

}

hidouki().then(function (value) {

  console.log(value);

}).catch(function (error) {

  console.log(error);

});

</script>

</body>

</html>

登录后复制

执行结果

2345截图20181211163457.png

以上是如何使用JavaScript中的promise对象的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章标签

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

在JavaScript中替换字符串字符 在JavaScript中替换字符串字符 Mar 11, 2025 am 12:07 AM

在JavaScript中替换字符串字符

jQuery检查日期是否有效 jQuery检查日期是否有效 Mar 01, 2025 am 08:51 AM

jQuery检查日期是否有效

jQuery获取元素填充/保证金 jQuery获取元素填充/保证金 Mar 01, 2025 am 08:53 AM

jQuery获取元素填充/保证金

10个jQuery手风琴选项卡 10个jQuery手风琴选项卡 Mar 01, 2025 am 01:34 AM

10个jQuery手风琴选项卡

10值得检查jQuery插件 10值得检查jQuery插件 Mar 01, 2025 am 01:29 AM

10值得检查jQuery插件

HTTP与节点和HTTP-Console调试 HTTP与节点和HTTP-Console调试 Mar 01, 2025 am 01:37 AM

HTTP与节点和HTTP-Console调试

自定义Google搜索API设置教程 自定义Google搜索API设置教程 Mar 04, 2025 am 01:06 AM

自定义Google搜索API设置教程

jQuery添加卷轴到Div jQuery添加卷轴到Div Mar 01, 2025 am 01:30 AM

jQuery添加卷轴到Div

See all articles