首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

什么是地狱?如何解决地狱问题_地狱

一、什么是地狱呢? 地狱这个词不陌生吧!对,没错就是那个十八层地狱地狱,一层一层的地狱。 1、同步API,异步API的区别 这个问题呢,需要从Node.js的API说起,这里就会有人问了?...博主你不是说地狱的问题吗,怎么说到API了,别急,看博主一步一步的解释给你听: 同步API 是从上到下依次执行,前面的代码会阻塞后面的代码执行 请看下面这个代码 这里我写了一个for询还1000次.../demo.txt’,(err,result) =>{}); console.log('文件打印结果') 3、写一个使用异步API,造成的地狱案例 案例需求:依次读取A文件,B文件,C文件 首先需要创建一个...这样一层嵌套一层,是不是有点像地狱的样子!这样的代码也不易去维护。 二、怎么解决地狱呢?...Promise的出现就是解决Node.js异步编程中地狱的问题 基础语法 let promise = new Promise((resolve,reject) =>{ setTimout(()

2.9K30
您找到你想要的搜索结果了吗?
是的
没有找到

地狱

,很恶心,就产生了地狱.本文,将为你揭晓怎么避免地狱,您将在本文中了解到以下内容: 什么是地狱(函数作为参数层层嵌套) 什么是函数(一个函数作为参数需要依赖另一个函数执行调用) 如何解决地狱...这就是被称为地狱 地狱的原因是,当人们试图以一种从上到下的视觉方式执行JavaScript的方式编写JavaScript时。...事情发生的顺序不是从顶部到底部读取,而是基于事情完成时跳转 我该如何解决地狱?...任何有经验的开发人员都会告诉你,你永远无法知道这些错误何时发生,所以你必须对它们进行计划 通过,处理错误的最常见方法是Node.js样式,其中的第一个参数始终保留用于错误 var fs = require...Async functions异步函数是一个建议的ES7功能,它将以更高级别的语法进一步包装生成器和继承 总结 地狱最主要的就是因为功能逻辑代码嵌套的层次太多,导致可读性降低,维护困难,避免地狱的最重要的方面是将功能移开

2.3K10

JS】302- 地狱解决方案之Promise

}) 上述代码只是一层级,如果代码复杂后,会出现多层级的,代码可读性也会很差,那有没有一种方式,不用考虑里面的内容,直接根据结果成功还是失败执行下面的代码呢?...Promise的含义 书上这么说: Promise 是异步编程的一种解决方案,比传统的解决方案–函数和事件--更合理和更强大。...我的理解: Promise是函数可以规范的链式调用 Promise原理与讲解 原理 Promise的三种状态 pending:进行中 fulfilled :执行成功 rejected :执行失败...==Promise其实没有做任何实质的代码操作,它只是对异步操作函数的不同结果定义了不同状态。...这种情况,代码虽然看起来会比callback的简介和规范了很多,但是还是感觉一些复杂,有没有更好的解决办法呢?请看下一篇博客 的终极使用--async和await的讲解

1.3K30

asyncawait 地狱解决方案

问题背景 在 js 异步编程中,通过函数实现 当多个异步逻辑间产生顺序或关联逻辑,就会产生嵌套(地狱),导致代码丑陋且难以阅读,形如: fetch(function() { fetch(...从附录中阮一峰老师的文章中得出: 早期解决方案是 Promise,可以将横向代码通过 then 包装为纵向 更近一步的引出 Generator,而 async/await 即是 Generator 的语法糖 简单说,嵌套问题优化方案...,根据时间线整理为: 嵌套 -> Promise -> Generator(async/await) 使用 async/await 解决嵌套问题 看案例 index.html(可保存到本地运行)... 上述案例中,两次 callapi,第二次使用了第一次的返回值 await 方法阻塞当前行代码直到异步响应完成,使得异步代码可以用同步的写法,摆脱了嵌套问题

18830

地狱解决方案之Promise

}) 上述代码只是一层级,如果代码复杂后,会出现多层级的,代码可读性也会很差,那有没有一种方式,不用考虑里面的内容,直接根据结果成功还是失败执行下面的代码呢?...Promise的含义 书上这么说: Promise 是异步编程的一种解决方案,比传统的解决方案–函数和事件--更合理和更强大。...我的理解: Promise是函数可以规范的链式调用 Promise原理与讲解 原理 Promise的三种状态 pending:进行中 fulfilled :执行成功 rejected :执行失败...==Promise其实没有做任何实质的代码操作,它只是对异步操作函数的不同结果定义了不同状态。...这种情况,代码虽然看起来会比callback的简介和规范了很多,但是还是感觉一些复杂,有没有更好的解决办法呢?请看下一篇博客 的终极使用--async和await的讲解

73420

地狱解决方案之Promise

}) 上述代码只是一层级,如果代码复杂后,会出现多层级的,代码可读性也会很差,那有没有一种方式,不用考虑里面的内容,直接根据结果成功还是失败执行下面的代码呢?...Promise的含义 书上这么说: Promise 是异步编程的一种解决方案,比传统的解决方案–函数和事件--更合理和更强大。...我的理解: Promise使函数可以规范的链式调用 Promise原理与讲解 原理 Promise的三种状态 pending:进行中 fulfilled :执行成功 rejected :执行失败...==Promise其实没有做任何实质的代码操作,它只是对异步操作函数的不同结果定义了不同状态。...这种情况,代码虽然看起来会比callback的简介和规范了很多,但是还是感觉一些复杂,有没有更好的解决办法呢?

1.3K30

深入了解Promise对象,写出优雅的代码,告别地狱

then( ) 四、函数catch( ) 五、函数finally( ) 六、函数all( ) 七、实际应用 结束语 引言 我们都知道,一个好的代码是有很强的维护性、阅读性的, 但是在Jacascript中的函数的量一增多..., 很容易影响代码的阅读性,导致代码难以维护, 这种现象就叫做回地狱, 为了解决这现象, ES6将Promise写进了语言标准里, 专门用来解决这个地狱的现象, 那么就让我们来了解一下吧。...Promise简介 Promise 是异步编程的一种解决方案, 他能使得各种异步操作,都用同样的方式去处理, 将代码变得非常的统一, 使得维护和阅读都便利了很多, 我们现在简单看一下, 不用Promise时,函数的数量很多的时候的代码...{ console.log(data4) } }) }) 使用或不使用Promise, 这区别已经很明显了吧, 显而易见,使用完Promise后, 这种函数里面嵌套函数的代码就变得很简洁...时,就处于该状态,并且会then函数 reject: 拒绝状态,当我们主动调了reject时 , 就处于该状态,并且会catch函数 三、函数then( ) 函数 then 是Promise中的一个方法

52810

异步JavaScript:从地狱到异步和等待

异步JavaScript简史 第一个也是最直接的解决方案是以嵌套函数的形式作为。这个解决方案导致了所谓的地狱,而且太多的应用程序仍然感到它的燃烧。 然后,我们有了Promises。...方法1:地狱(“末日金字塔”) 对这些调用进行同步的古老解决方案是通过嵌套。对于简单的异步JavaScript任务来说,这是一种不错的方法,但是由于一个名为地狱的问题而无法扩展。 ?...一旦你意识到database.getRoles是嵌套的的另一个函数,这个例子变得更加复杂。...JavaScript Promises Promises是逃避地狱的下一个合乎逻辑的步骤。这个方法并没有去掉函数的使用,但是它使得函数的链接简单明了,简化了代码,使得它更容易阅读。 ?...什么是地狱? 在JavaScript中,地狱是代码中的一种反模式,这是由于异步代码结构不良造成的。

3.6K10

JS 模式

示例 如果有个模块 findeNodes() ,任务是找到期望的 DOM 元素并使用 hide() 处理: function findNodes() { var i = 10000, nodes...可以将节点隐藏逻辑以函数的方式传递给 findNodes() 并委托执行: function findNodes(callback) { var i = 10000, nodes = [],...,重构后加入函数参数的 findNodes() 仍然可以像以前一样使用,而不会破坏旧 API 的原始代码。...与作用域 前面的例子中,执行的语句:callback(para),在多数情况下有效,但是如果传递的函数是对象的方法且有 this 那么方法里的 this 将指向的是全局对象,从而发生意外。...抽象工厂模式 JS 工厂模式 JS 建造者模式 JS 原型模式 JS 单例模式 JS 模式 JS 外观模式 JS 适配器模式 JS 利用高阶函数实现函数缓存(备忘模式) JS 状态模式 JS 桥接模式

3.5K10

js函数的

平常的前端开发工作中,编写js时会有很多地方用到函数的。..."); } doSomething(foo); /*正确*/ doSomething(function(){ alert("我是后执行的函数"); }); /*正确*/ doSomething(..."foo"); /* 这样是不行的,传入的是一个字符串,不是一个函数名 */ 以上只能没有参数的(除法你事先知道的函数的参数),如果函数有未知的函数,就不能如此简单的调用了。...有了上面的基础,就能看的懂工作中封装好的js函数了 背景:页面A需要使用页面B来选择某个项目,然后带回这个项目的信息给页面A,页面A根据这些信息丰富自己。...} newsee.util.url.back(callback, arr[0]) //重点来了,这里执行,将需要回的函数名和入参传进来,arr[0]就是选择的项目的对象的数组了(它也是个数组,里面就一个对象

4.5K30

js函数详解

在我们看更多的实际例子和编写我们自己的函数之前,先来理解函数是怎样运作的。 函数是怎样运作的?...实现函数的基本原理 函数并不复杂,但是在我们开始创建并使用毁掉函数之前,我们应该熟悉几个实现函数的基本原理。...favicon.png", success:successCallback, complete:completeCallback, error:errorCallback}); “地狱...这些杂乱无章的代码叫做回地狱因为太多而使看懂代码变得非常困难。我从node-mongodb-native,一个适用于Node.js的MongoDB驱动中拿来了一个例子。...这段位于下方的代码将会充分说明地狱: var p_client = new Db('integration_tests_20', new Server("127.0.0.1", 27017, {}

5.8K50
领券