JavaScript日常笔记

闭包

  • 定义在函数内部的函数,可以访问其外部的变量、函数
  • 函数可以访问其所在词法环境的变量、函数

for of 和 for in 的区别

for in 遍历的是对象属性名、数组的键名;for of 可迭代对象定义的迭代值,调用的是可迭代对象的 iterator 函数。

es6 函数非尾部默认值

function f(x = 1, y) {
  return [x, y];
}

f() // [1, undefined]
f(2) // [2, undefined])
f(, 1) // 报错
f(undefined, 1) // [1, 1]

这个问题应特别注意

关于箭头函数

  1. 箭头函数不会创建自己的this,它使用封闭执行上下文环境的this值
  2. 不可以当作构造函数,也就是说,不可以使用new命令,否则会抛出一个错误
  3. 不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用 rest 参数代替
  4. 不可以使用yield命令,因此箭头函数不能用作 Generator 函数

关于严格模式

  1. 变量必须声明后再使用
  2. 函数的参数不能有同名属性,否则报错
  3. 不能使用with语句
  4. 不能对只读属性赋值,否则报错
  5. 不能使用前缀 0 表示八进制数,否则报错
  6. 不能删除不可删除的属性,否则报错
  7. 不能删除变量delete prop,会报错,只能删除属性delete global[prop]
  8. eval不会在它的外层作用域引入变量
  9. eval和arguments不能被重新赋值
  10. arguments不会自动反映函数参数的变化
  11. 不能使用arguments.callee
  12. 不能使用arguments.caller
  13. 禁止this指向全局对象
  14. 不能使用fn.caller和fn.arguments获取函数调用的堆栈
  15. 增加了保留字(比如protected、static和interface)

ES6 模块与 CommonJS 模块的差异

  1. CommonJS 模块输出的是一个值的拷贝,ES6 模块输出的是值的引用
  2. CommonJS 模块是运行时加载,ES6 模块是编译时输出接口

Error 对象

  1. Error: 通用 Error 对象,参考链接:请点击
  2. EvalError: 执行全局的 eval 函数发生错误时的 Error 对象(还未纳入当前 es 版本中),参考链接:请点击
  3. InternalError: js 执行引擎内部错误的 Error 对象(尚未未标准化),参考链接:请点击
  4. RangeError: 数据值不在集合或者允许的值范围之内时的 Error 对象,参考链接:请点击
  5. ReferenceError: 使用某个变量时,如果该变量未定义时的 Error 对象,参考链接:请点击
  6. SyntaxError: js 引擎在对文件进行语法解析出现语法错误时的 Error 对象,参考链接:请点击
  7. TypeError: 数据值不是期望的数据类型时的 Error 对象,参考链接:请点击
  8. URIError: 全局的 URI 处理函数被错误地使用时的 Error 对象,参考链接:请点击

由于上述所述内容,截止到 2018/01/03,部分存在尚未标准化的问题(error 的类型、constructor 的入参等),因此应避免使用未标准化的内容,以免造成语法错误。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿祥_csdn

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值