zoukankan      html  css  js  c++  java
  • 29 promise

    promise
    	在JavaScript的世界中,所有代码都是单线程执行的。
    	由于这个“缺陷”,导致JavaScript的所有网络操作,浏览器事件,都必须是异步执行。异步执行可以用回调函数实现
    
    	Promise对象一定会执行函数(承诺)然后,根据结果是成功还是失败,在将来的某个时候调用then函数或catch函数
    		例子:
    			new Promise(test).then(function (result) {
    				console.log('成功:' + result);
    			}).catch(function (reason) {
    				console.log('失败:' + reason);
    			});
    	可见Promise最大的好处是在异步执行的流程中,把执行代码和处理结果的代码清晰地分离了
    
    	串行执行异步任务
    		job1.then(job2).then(job3).catch(handleError);
    
    	并行执行异步任务
    		var p1 = new Promise(function (resolve, reject)
    		setTimeout(resolve, 500, 'P1');
    		});
    		var p2 = new Promise(function (resolve, reject) {
    			setTimeout(resolve, 600, 'P2');
    		});
    		// 同时执行p1和p2,并在它们都完成后执行then:
    		Promise.all([p1, p2]).then(function (results) {
    			console.log(results); // 获得一个Array: ['P1', 'P2']
    		});
    		
    		
    		var p1 = new Promise(function (resolve, reject) {
    			setTimeout(resolve, 500, 'P1');
    		});
    		var p2 = new Promise(function (resolve, reject) {
    			setTimeout(resolve, 600, 'P2');
    		});
    		// 同时执行p1和p2,仅要1个完成后执行then:
    		Promise.race([p1, p2]).then(function (result) {
    			console.log(result); // 'P1'
    		});
    

      

  • 相关阅读:
    javascript中 分号的问题
    IIFE(立即执行函数表达式)
    函数_回调函数
    数据_变量_内存
    严格区别变量类型与数据类型
    什么时候给变量赋值为null
    JavaScript Promise迷你书(中文版)
    python txt文件读写(追加、覆盖)
    python re:正向肯定预查(?=)和反向肯定预查(?<=)
    python re:正则表达式中使用变量
  • 原文地址:https://www.cnblogs.com/xuanjian-91/p/10998589.html
Copyright © 2011-2022 走看看