forkJoin: When all observables complete emit the last value from each. productMap: Map<number, IProduct> ngOnInit() { const cart = this.stockService.getCartItems(); const products = this.stockService.getProducts(); Observable.forkJoin( cart, product…
所有人都谈论道workflows支持ECMAScript6里出现的令人吃惊的新特性,因此我们很容易忘掉ECMAScript5带给我们一些很棒的工具方法来支持在JavaScript里进行函数编程,这些工具方法我们现在可以使用了.在这些函数方法里主要的是基于JavaScript 数组对象的map()方法和reduce()方法. 如果你如今还没有使用map()和reduce()方法,那么现在是时候开始使用了.如今绝大部分的JavaScript开发平台都与生俱来的支持ECMAScript5.使用Map方…
javascript中的promise和deferred:实践(二) 介绍: 在第一节呢,我花了大量的时间来介绍promises和deferreds的理论.现在呢,我们来看看jquery中的promises(作者一会儿用单数,一会儿用复数形式,妹的). Note:代码示例将使用jQuery,尽管它偏离了Promise/A 协议. 排序模式: deferred就是一个未完成的对象,promise呢则是一个未知的值.换句话说,prmises/deferreds 允许我们描述(represent)简单…
javascript实现java中的Map,代码是在国外的一个网站上看到的(http://stackoverflow.com/questions/368280/javascript-hashmap-equivalent),自己稍作了修改,之前也看到过有人用2个数组实现了Map,但是我感觉效率比较低,现在这个我感觉效率还可以,自己做了下测试,代码如下: Map.js function Map(linkItems) { this.current = undefined; this._size = 0…
<script> var arr = [2,3,6,7,9]; //javascript中的forEach 和 map方法 arr.forEach(function(value,index){//(值,索引) console.log(value); }); arr.map(function(value,index){//(值,索引) console.log(value); }); //jQuery的 each map方法 $(arr).each(function(index,value){//…
JavaScript中的Promise[期约] 期约主要有两大用途 首先是抽象地表示一个异步操作.期约的状态代表期约是否完成. 比如,假设期约要向服务器发送一个 HTTP 请求.请求返回 200~299 范围内的状态码就足以让期约的状态变为"兑现".类似地,如果请求返回的状态码不在 200~299 这个范围内,那么就会把期约状态切换为"拒绝". 由于期约的状态是私有的,所以只能在内部进行操作.内部操作在期约的执行器函数中完成.执行器函数主要有两项职责:初始化期约的异…
当我还是一个小白的时候,我翻了很多关于Promise介绍的文档,我一直没能理解所谓解决异步操作的痛点是什么意思 直到我翻了谷歌第一页的所有中文文档我才有所顿悟,其实从他的英文字面意思理解最为简单粗暴 这就是一个承诺,相当于在代码中提供一个在任何时候承诺之后要做什么事的方式,这个承诺可能会兑现也可能无法兑现,当然也可能在兑现的过程中 用这个来替代我们曾经需要写的回调函数,可以避免JavaScript程序中的回调地狱 所以先不去学习的语法,从另一个方式先理解,希望可以帮助你更好的学习或上手Promi…
事件循环 基本介绍 JavaScript是一门单线程的编程语言,所以没有真正意义上的并行特性. 为了协调事件处理.页面交互.脚本调用.UI渲染.网络请求等行为对主线程造成的影响,事件循环(event loop)方案应运而生. 事件循环说白了就是一个不断的在等待任务.执行任务的方案. 在JavaScript中,根据执行方式的不同,有2种状态的任务,分别是同步任务和异步任务. 同步任务率先执行,而后执行异步任务,所有的异步任务由2个队列存储,分别是: 微任务队列 宏任务队列 主线程在执行完同步任务后…
 本文是笔者在看廖雪峰老师JavaScript教程时的个人总结      一些判断条件                 JavaScript把null.undefined.0.NaN和空字符串''视为false,其他值一概视为true,因此上述代码条件判断的结果是true      循环          1.for(同C)           2.while (同C)            3.do while(同C)        变体  for...in                遍历…
因为前几天做了一个promise对象捕获错误的面试题目,所以这几天又重温了一下promise对象.现在借这道题来分享下一些很基础的知识点. 下面是一个面试题目,三个promise对象捕获错误的例子,返回结果有什么不同. //使用throw添加错误事件 var p = new Promise(function(resolve, reject) { resolve("ok"); throw new Error('error0'); //setTimeout(function() { thr…
Promise定义 Promise是CommonJs的规范之一,包含resolve,reject,done,fail,then等方法,能够帮助我们控制代码的流程,避免函数的多层嵌套.异步在web开发中越来越重要,对于开发人员来说,J非线性执行的编程会让开发者觉得难以掌控,而Promise可以让我们更好地掌控代码的执行流程,jQuery等流行的js库都已经实现了这个对象,现在ES6已经原生实现了Promise. 场景说明: 有时候会遇到这样的情况,需要发两个异步请求,而第二个请求需要用到第一个返回…
索引 回调版本 Promise版本1 Promise版本2 Notes 参考资料: Promise JavaScript Promise:简介 你去书店借书,按照异步的套路,剧情如下↓ 你:“老板,有xxx吗?” 老板:“你等下,我得找一找看,到时候打电话给你.” 然后你就去做其它事情了. 1.回调版本: // 辅助函数 const randomBoolean = () => { return Math.random() < 0.5; }; // 客户对象,处理找书的结果 const cust…
ES6原生提供了 Promise 对象. 到底是何方妖怪呢?打出来看看: 所谓 Promise,就是一个对象,用来传递异步操作的消息.它代表了某个未来才会知道结果的事件(通常是一个异步操作),并且这个事件提供统一的 API,可供进一步处理. Promise 对象有以下两个特点. (1)对象的状态不受外界影响.Promise 对象代表一个异步操作,有三种状态:Pending(进行中).Resolved(已完成,又称 Fulfilled)和 Rejected(已失败).只有异步操作的结果,可以决定当…
The AbortController interface enables us to cancel a one or more DOM requests. In this lesson, we will demonstrate how to use the controller to cancel a Javascript Promise before it is resolved. const controller = new AbortController(); const signal…
一般下载都是直接打开一个链接就行.var URL = 'XXXX';window.open(URL)其实这样会有些问题:1. 浏览器禁止打开新窗口,导致无法下载 那么怎么解决呢?这样: <a href="http://somehost/somefile.zip" download="filename.zip">Download file</a> 注意download属性,它说明要下载,并且文件名:filename.zip 那么如何异步下载?J…
在线阅读 https://www.kancloud.cn/chenmk/web-knowledges/1080519 数组 isArray():Array.isArray(value) 用于检测变量是否为数组类型 toString():把数组转换为字符串,并返回结果,每一项以逗号分隔 push() & pop():push() 方法用于数组末尾添加项,pop() 方法弹出数组末尾项并返回该项 shift() & unshift():移除数组中的第一个项并返回该项 / 数组最前端添加项 re…
Promise解决的问题相信每个前端都遇到过这样一个问题,当一个异步任务的执行需要依赖另一个异步任务的结果时,我们一般会将两个异步任务嵌套起来,这种情况发生一两次还可以忍,但是发生很多次之后,就形成了所谓的回调地狱,代码层层嵌套,环环相扣,很明显,逻辑稍微复杂一些,这样的程序就会变得难以维护.就比如我们昨天的那个回调地狱的例子: function funA(callback) { console.log("A"); setTimeout(() = > { callback() }…
Learn how to query an Immutable.Map() using get, getIn, has, includes, find, first and last. These are powerful operators that make finding data in an object graph pain free. has, includes, contains: //has() var map = Immutable.Map({a: '10'}); consol…
We will now look at five methods that modify an Immutable.Map(). set update delete clear merge //set() var map = Immutable.Map(); var todo = { id: +new Date(), name: "todo1", content: "learning Immutable" } map = map.set(todo.id, todo)…
参考自: http://m.jb51.net/article/102642.htm 1.基本用法: (1).首先我们new一个Promise,将Promise实例化 (2).然后在实例化的promise可以传两个参数,一个是成功之后的resolve,一个是失败之后的reject (3).Promise实例生成以后,可以用then方法分别指定Resolved状态和Reject状态的回调函数 代码如下: var p1 = function(flag) { return new Promise(fun…
Set数据结构 类似数组,所有的数据都是唯一的,没有重复值,它本身是一个构造函数 size 数据长度 add() 添加一个数据 delete() 删除一个数据 has() 查找一个数据 clear() 删除所有数据 //重复的数据会被删除 let set = new Set([1,1,2,3,4]); console.log(set) console.log(set.size)//4 //添加 console.log(set.add(5));//Set(5) {1, 2, 3, 4, 5} //…
Set Set 对象允许储存任何类型的唯一值,无论是原始值或者是对象引用 本质:构造函数,用来生成 Set 数据结构 描述 Set 对象是值的集合,你可以按照插入的顺序迭代它的元素.Set 中的元素只会出现一次,即 Set 元素是唯一的. 相当于集合,可以进行并集交集运算. 值的相等 对于原始数据类型(boolean,number,string,null,undefined),如果储存相同值则只保存一个,对于引用类型,引用地址完全相同则只会存一个. +0 与-0 在存储判断唯一性的时候是恒等的,…
Promise Promise 介绍 Promise 对象表示一个异步操作的最终完成(或失败)及其结果值. 状态: 一个 promise 必然处于以下几种状态之一 待定:初始状态(pending) 已兑现:操作成功完成(fulfilled) 已拒绝:操作失败(reject) 创建 Promise Promise 对象是由关键字 new 及其构造函数来创建的.该构造函数会把一个叫做"处理器函数"(executor function)的函数作为它的参数.这个"处理器函数"…
这个问题我是希望有很多人可以一起交流的: 我在 http://blog.csdn.net/justjavac/article/details/19473199#t0 上看到了比较详细的解释, 但是具体的机制却不是很能理解,想不明白的朋友们可以戳这个网址 如果有关于这个问题的解释 我会加以补充…
Promise in js 回调函数真正的问题在于他剥夺了我们使用 return 和 throw 这些关键字的能力.而 Promise 很好地解决了这一切. 2015 年 6 月,ECMAScript 6 的正式版 终于发布了. ECMAScript 是 JavaScript 语言的国际标准,JavaScript 是 ECMAScript 的实现.ES6 的目标,是使得 JavaScript 语言可以用来编写大型的复杂的应用程序,成为企业级开发语言. 概念 ES6 原生提供了 Promise 对…
http://www.html-js.com/article/Promise-translation-JavaScript-Promise-devil-details 原文链接:JavaScript Promises … In Wicked Detail 我在 JavaScript 中使用 Promise 已经有一段时间了,目前我已经能高效的使用这一开始让我晕头转向的 东西.但真要细说起来,我发现还是不能完全理解它的实现原理,这也正是本文写作的目的所在.如果诸位读者也处在一知半解的状态,那请读完…
什么是Promise? 其实, Promise就是一个类,而且这个类已经成为ES6的标准,是 ECMAScript 6 规范的重要特性之一.这个类目前在chrome32.Opera19.Firefox29以上的版本都已经支持了,要想在所有浏览器上都用上的话就看看es6-promise吧. ES6 的 Promises 是采用了 Promises/A+ 提案的一种实现.你现在能够找到的各种第三方实现,如果是完全兼容了 Promises/A+ 的,那么就和 ES6 的 Promises 是一致的(当…
原文:http://www.html5rocks.com/en/tutorials/es6/promises/ 作者:Jake Archibald 翻译:Amio 女士们先生们,请准备好迎接 Web 开发历史上一个重大时刻-- [鼓声响起] JavaScript 有了原生的 Promise! [漫天的烟花绽放,人群沸腾了] 这时候你大概是这三种人之一: 你的身边拥挤着欢呼的人群,但是你却不在其中,甚至你还不大清楚"Promise"是什么.你耸耸肩,烟花的碎屑在你的身边落下.这样的话,不…
是什么? https://www.promisejs.org/ What is a promise? The core idea behind promises is that a promise represents the result of an asynchronous operation. A promise is in one of three different states: pending - The initial state of a promise. fulfilled…
构建异步API的一种流行的替代方式是使用promise(有时也被称为deferred或future)模式.已经在本章讨论过的异步API使用回调函数作为参数. downloadAsync('file.txt',function(file){ console.log('file:'+file); }); 基于promise的API不接收回调函数作为参数.相反,它返回一个promise对象,该对象通过其自身的then方法接收回调函数. var p=downloadP('file.txt'); p.th…