如何深入理解并解决JavaScript面试中的复杂异步编程问题?
- 内容介绍
- 文章标签
- 相关推荐
本文共计986个文字,预计阅读时间需要4分钟。
JavaScript中的宏任务与微任务+面试中,基本面试官都会问你一些关于Promise的问题。Promise是ES6的新内容,主要用于优化异步问题。面试中经常让你写一些Promise和setTimeout的执行结果。
js中的宏任务与微任务
在面试过程中,基本面试官都会问你一些promise的问题,promise是es6的新内容,主要是用来优化异步的问题。笔试中经常会让你写一些promise和setTimeout的执行结果,这你就必须知道宏任务和微任务的概念了!
为什么要使用promise
如果你经历过以前的jquery开发项目,你会遇到以下问题:回调地狱
$.ajax({ ... success: function() { ... $.ajax({ ... success: function() { } }) ... } })
原因分析:
ajax请求嵌套,原因是我第二个请求依赖的参数在第一个请求的结果中,所以就得这么一直嵌套下去,ajax是异步的,不能再外面拿到里面的结果。这种代码导致的问题就是调试困难,耦合性非常高,后期改动一个地方就头疼!维护非常困难,代码可读性差。
于是乎就引入了promise对ajax进行了优化,axios就是基于promise的一个请求封装库,他们底层都是基于js原生的XMLHTTPREQUEST.
promise().then().catch()链式调用,多个请求可以promise().then().then()。
本文共计986个文字,预计阅读时间需要4分钟。
JavaScript中的宏任务与微任务+面试中,基本面试官都会问你一些关于Promise的问题。Promise是ES6的新内容,主要用于优化异步问题。面试中经常让你写一些Promise和setTimeout的执行结果。
js中的宏任务与微任务
在面试过程中,基本面试官都会问你一些promise的问题,promise是es6的新内容,主要是用来优化异步的问题。笔试中经常会让你写一些promise和setTimeout的执行结果,这你就必须知道宏任务和微任务的概念了!
为什么要使用promise
如果你经历过以前的jquery开发项目,你会遇到以下问题:回调地狱
$.ajax({ ... success: function() { ... $.ajax({ ... success: function() { } }) ... } })
原因分析:
ajax请求嵌套,原因是我第二个请求依赖的参数在第一个请求的结果中,所以就得这么一直嵌套下去,ajax是异步的,不能再外面拿到里面的结果。这种代码导致的问题就是调试困难,耦合性非常高,后期改动一个地方就头疼!维护非常困难,代码可读性差。
于是乎就引入了promise对ajax进行了优化,axios就是基于promise的一个请求封装库,他们底层都是基于js原生的XMLHTTPREQUEST.
promise().then().catch()链式调用,多个请求可以promise().then().then()。

