一.Promise入门准备阶段
一.Promise入门准备阶段
1.区别实例对象呵函数对象
- 实例对象: new 函数产生的对象,称为实例对象,简称为对象
- 函数对象:将函数作为对象使用时,简称为函数对象
function F() { //F函数
}
const f = new F() //F是构造函数,f是实例对象,简称为对象
console.log(F.prototype) //F是函数对象
F.call({}) //F是函数对象
$("#root") //jQuery函数
$.get('./test') //jQuery函数对象
2.两种类型的回调函数(同步与异步)
2.1 同步回调
理解:立即执行,完全执行完了才结束,不会放入回调队列中
例子:数组遍历相关的回调函数 / Promise的excutor函数
const arr = [1, 2, 3];
arr.forEach(item => { //遍历回调,同步回调函数,不会放入队列,一上来就执行
console.log(item);
});
console.log("forEach()之后");
2.2 异步回调
- 理解:不会立即执行,会放入回调队列中将来执行
- 例子:定时器回调 / ajax回调 / Promise的成功|失败的回调
setTimeout( () => { //异步回调函数,会放入队列中将来执行
console.log("timeout callback()");
}, 0);
console.log("setTimeout()之后");
3.JS的error处理
3.1 错误的类型
Error:所有错误的父类型
ReferenceError:引用的变量不存在
TypeError:数据类型不正确的错误
RangeError:数据值不在其所允许的范围内
SyntaxError:语法错误
// 常见的内置错误
// 1.ReferenceError:引用的变量不存在
console.1og(a) // ReferenceError: a is not defined
console.log('-----')// 没有捕获error,下面的代码不会执行
// 2.TypeErron: 数据类型不正确的错误
let b
console.1og(b.xxx) // TypeError: Cannot read property "XXX" of undefined
b=0
b.xxx()// TypeError:b.xxx is not a function
// 3.RangeError: 数据值不在其所允许的范围内
function fn(){
fn()
}
fn() // RangeError:Maximum call stack size exceeded
// 4.SyntaxError:语法错误
const c ="""" // SyntaxError:Unexpected string
3.2 错误处理与错误对象
错误处理:
捕获错误: try … catch
抛出错误:throw error
错误对象:
- message属性:错误相关信息
- stack属性:函数调用栈记录信息
在捕获错误时进入调试模式,可以看到:

// 错误处理
// 捕获错误:try ...catch
try {
let d;
console.log(d.xxx);
} catch (error) {
console.log(error);
console.log(error.message)
console.log(error.stack)
}
console.1og('出错之后');
// 抛出错误:throw error
function something() {
if(Date.now()%2===1) {
console.1og('当前时间为奇数,可以执行任务');
}
else {
throw new Error('当前时间为偶数无法执行任务')//传入message
}
}
// 捕获处理异常
try {
something()
} catch (error) {
alert(error.message)
}
一.Promise入门准备阶段的更多相关文章
- Promise入门到精通(初级篇)-附代码详细讲解
Promise入门到精通(初级篇)-附代码详细讲解 Promise,中文翻译为承诺,约定,契约,从字面意思来看,这应该是类似某种协议,规定了什么事件发生的条件和触发方法. Pr ...
- promise入门基本使用
Promise入门详解和基本用法 异步调用 异步 JavaScript的执行环境是单线程. 所谓单线程,是指JS引擎中负责解释和执行JavaScript代码的线程只有一个,也就是一次只能完成一项任 ...
- Javascript Promise入门
是什么? https://www.promisejs.org/ What is a promise? The core idea behind promises is that a promise r ...
- 移动开发 android 入门开发 阶段视频
一直想把 android 的开发学习录制成视频,这里录制了一部分供大家学习. http://www.chuanke.com/s5402069.html 到这里,文档,源码,视频基本就全了,祝愿大家能够 ...
- promise入门demo
<!DOCTYPE html> <html> <head> <title></title> </head> <body&g ...
- HoloLens开发手记 - 入门学习阶段总结
伴随着数月的期待,终于拿到了预订的HoloLens开发者版本套件.随着VR/AR/MR技术的热潮,国内外均对它们的应用与盈利前景持有积极的预期,这也直接导致了国内外当前投资VR/AR/MR技术的热潮. ...
- javaScript Promise 入门
Promise是JavaScript的异步编程模式,为繁重的异步回调带来了福音. 一直以来,JavaScript处理异步都是以callback的方式,假设需要进行一个异步队列,执行起来如下: anim ...
- Promise 入门与使用
Tags: ECMAScript6 参考资料 promises-book Promise对象 we-have-a-problem-with-promises Promise最初被提出是在 E语言中, ...
- Promise入门详解
异步调用 异步 JavaScript的执行环境是单线程. 所谓单线程,是指JS引擎中负责解释和执行JavaScript代码的线程只有一个,也就是一次只能完成一项任务,这个任务执行完后才能执行下一个,它 ...
随机推荐
- 不关闭selinux下配置php+httpd访问KingbaseES
在不关闭selinux的情况下使httpd+php+KingbaseES正常使用1.正常设置php.apache 除了正常流程外还需要在/etc/sysconfig/httpd最后追加LD_LIBRA ...
- P4480-[BJWC2018]餐巾计划问题【三分,贪心】
正题 题目链接:https://www.luogu.com.cn/problem/P4480 题目大意 \(n\)天,第\(i\)天需要\(a_i\)个餐巾. 每个餐巾价格为\(p\),使用完后有两种 ...
- HttpRunner3.X - 全面讲解如何落地项目实战
一.前言 接触httprunner框架有一段时间了,也一直探索如何更好的落地到项目上,本篇主要讲述如何应用到实际的项目中,达到提升测试效率的目的. 1.项目难题 这个月开始忙起来了,接了个大项目,苦不 ...
- 数值计算:四阶龙格-库塔法 for 二阶微分方程
引言 考虑存在以下二阶偏微分方程 \[\begin{align} f_2 \cdot \ddot{X(t)}+f_1 \cdot \dot{X(t)} +f_0 \cdot {X(t)} =F(t) ...
- bzoj1503 郁闷的出纳员(平衡树,思维)
题目大意: 现在有n个操作和一个最低限度m \(I\)命令\(I\ k\)新建一个工资档案,初始工资为k. \(A\)命令$A\ k $把每位员工的工资加上k \(S\)命令$S\ k $把每位员工的 ...
- Miller Rabin 详解 && 小清新数学题题解
在做这道题之前,我们首先来尝试签到题. 签到题 我们定义一个函数:\(qiandao(x)\) 为小于等于 x 的数中与 x 不互质的数的个数.要求 \(\sum\limits _{i=l}^r qi ...
- Flutter随笔(二)——使用Flutter Web + Docker + Nginx打造一个简单的Web项目
前言 Flutter作为一个跨平台UI框架,功能十分强大,仅用一套代码便能编译出Android.iOS.Web.windows.macOS.Windows.Linux等平台上的应用,各平台应用体验高度 ...
- k8s学习笔记(2)- Rancher2.x部署springboot应用及高可用、扩容
前言:上一篇介绍基于k3s环境,使用kubectl部署springboot简单项目应用,本篇介绍基于rancher2.x部署应用程序 1.上篇已部署一个springboot应用,我们可以通过ranch ...
- vps实现私人代码托管并用nginx部署hexo
个人博客 原本我的博客是通过github pages搭建的,但由于一些众所周知的原因,即使套上了CDN依旧是访问状态令人堪忧,经常会造成各种各样的问题,并且由于不存在服务器也不好进行进一步的管理,更不 ...
- python join的用法
joinn其实就相当于用某个字符串来拼接列表或者元组中的元素 当然也可以将字符串以某一个str拼接起来 得出的结果自然也是字符串 ex1: results: 实例用处: 当我们从某个文件中读出内容时, ...