Get to know MDN better
此页面由社区从英文翻译而来。了解更多并加入 MDN Web Docs 社区。
本附录列出了那些已经废弃(仍然可用,但是已计划删除)或者过时(已被删除,无法使用)的 JavaScript 特性。
这些废弃的特性仍然可以使用,但是使用时一定要保持谨慎,因为它们很可能会在未来的某个时间点被移除。应当将其从需要使用的代码中移除。
ECMAScript 规范的 Annex B 部分列出了其中的一些废弃功能。这一部分被描述为规范性的可选功能,也就是说,web 浏览器主机必须实现这些功能,而非 web 主机可以不实现。这些功能很可能是稳定的,因为删除它们会导致向下兼容的问题,并破坏传统的网站(JavaScript 的设计目标是“不要破坏 web”)。尽管如此,它们还是不能跨平台移植,而且可能不被所有的分析工具所支持,所以建议你不要使用它们,正如 Annex B 的介绍所说:
… All of the language features and behaviors specified in this annex have one or more undesirable characteristics and in the absence of legacy usage would be removed from this specification.(本附录中规定的所有语言特性和行为都有一个或多个不理想的特性,在没有遗留使用的情况下,将从本规范中删除。) …
… Programmers should not use or assume the existence of these features and behaviors when writing new ECMAScript code.(程序员在编写新的 ECMAScript 代码时,不应该使用或假设这些特性和行为的存在。) …
其他一些,尽管在规范主体中,也被标记为规范性可选,不应该依赖它们。
如果 JavaScript 源码被作为脚本代码解析,它允许 HTML 注释,就像这些脚本是 <script> 的标签一部分那样。
以下是在 web 浏览器(或使用支持 Chrome 的 V8 引擎的 Node.js)中运行的有效 JavaScript 代码:
<!-- 和 --> 的作用都与 // 类似,即起始行注释。--> 只在行首有效(以避免与紧跟大于运算符的后缀式自减相混淆),而 <!-- 可以出现在行的任何地方。
下面的这些属性已经被废弃。这并不影响它们在替换字符串中的使用。
$1–$9括号内的子串匹配结果。
input, $_用于匹配正则表达式的字符串。
lastMatch, $&最后匹配的子串。
lastParen, $+最后一个括号内的子串匹配。
leftContext, $`最近一次匹配前的子串。
rightContext, $'最近一次匹配后的子串。
警告:避免使用这些静态属性,因为它们可能导致与外部代码交互时的问题!
compile() 方法已被废弃,请构造一个新的 RegExp 实例。
caller 和 arguments 属性已经废弃,因为它们会泄漏调用函数的对象。应当在函数内部使用 arguments 对象来代替函数的 arguments 属性。
with 语句在严格模式中已被弃用且不可用。
在严格模式下,for...in 循环头的 var 声明中的初始化器被弃用并产生语法错误。在非严格模式下,它们会被静默地忽略。
这些过时的功能已经从 JavaScript 中完全删除,从指定的 JavaScript 版本开始就不能再使用了。
以下是 RegExp 实例的属性,不再是 RegExp 构造函数的属性:
| global | 是否针对字符串中所有可能的匹配进行正则表达式测试,或者只针对第一个匹配进行测试。 |
| ignoreCase | 在尝试匹配一个字符串时是否忽略大小写。 |
| lastIndex | 开始下一次匹配的索引。 |
| multiline(也可通过 RegExp.$*) | 是否在多行的字符串中搜索。 |
| source | 模式的文本。 |
valueOf() 方法不再专门用于 RegExp。它使用 Object.prototype.valueOf(),并返回它本身。
| __count__ | 返回直接在用户定义的对象上的可枚举属性的数量。 | Object.keys() |
| __parent__ | 指向对象的上下文 | 没有直接的替换方法 |
| __iterator__ | 和遗留的生成器和迭代器一起使用。 | Symbol.iterator 和新的迭代协议 |
| __noSuchMethod__ | 当一个不存在的属性被作为方法调用时,这个方法被调用。 | Proxy |
| Object.prototype.eval() | 在指定对象的上下文中评估 JavaScript 代码字符串。 | 没有直接的替换方法 |
| Object.observe() | 异步地观察一个对象的变化。 | Proxy |
| Object.unobserve() | 移除观察器。 | Proxy |
| Object.getNotifier() | 创建一个通知者对象,允许用 Object.observe() 来综合触发一个变化的观察者。 | 没有直接的替换方法 |
| Object.prototype.watch() | 在一个属性上附加一个处理器回调,当属性被分配时被调用。 | Proxy |
| Object.prototype.unwatch() | 移除一个属性上的观察处理器。 | Proxy |
非标准的 Array 通用方法,如 Array.slice(myArr, 0, 12)、Array.forEach(myArr, myFn) 等,在 Firefox 1.5(JavaScript 1.6)中引入,在 Firefox 68 中被废弃,并在 Firefox 71 中删除。你可以使用 Array.prototype 和 Function.call 来代替。
| Array.observe() | 异步地观察数组的变化 | Proxy |
| Array.unobserve() | 移除观察器。 | Proxy |
数组、数字、字符串等的 toSource() 方法和 uneval() 全局函数已经过时。使用 toString(),或者编写你自己的序列化方法来代替。
遗留的生成器函数语句和遗留的生成器函数表达式被移除。传统的生成器函数语法重用了 function 关键字,当主体中有一个或多个 yield 表达式时,它自动成为生成器函数——现在这是一个语法错误。使用 function* 语句和 function* 表达式代替。
数组推导式和生成器推导式已被移除。
Firefox 26 版本之前实现了另一个迭代器协议,与标准的迭代器协议类似。当一个对象实现了 next() 方法时,它就是一个遗留的迭代器,该方法在每次调用时产生一个值,并在迭代结束时抛出一个 StopIteration 对象。这种遗留迭代器协议与标准迭代器协议不同:
这个功能,连同 StopIteration 全局构造函数,在 Firefox 58+ 中被移除。未来可以使用 for...of 循环和迭代器协议。
变量引用语法已经过时。要创建循环结构,请使用临时变量代替。