写点什么

ECMAScript 5 正式发布

  • 2009-12-12
  • 本文字数:1399 字

    阅读完需:约 5 分钟

这周 ECMAScript 5 也即众所周知的 JavaScript 正式发布了( pdf ),在给基本库带来更新的同时,还引入了更加严格的运行时模型,来帮助定位并移除通常的代码错误。

而早期对于 ECMAScript 4 的标准化工作基本就算是失败了;只有 Adobe 的 ActionScript 是基于建议的变化的。ECMA 甚至都没有发布一个版本 4 的规范,因为不同的组织对于发展的进度并不满意;就这样,也没有浏览器来支持它了。

在过去的几年,随着 JavaScript 引擎的大力改善,比如 Nitro TraceMonkey ,JavaScript 已经极具性能,以 Google Wave 为代表的在线协作应用可以证明这一点。甚至还有伴随 GWT 2.0 发布的 Google Chrome 扩展 Speed Tracer ,来帮助优化 JavaScript 应用的性能。

从这点上来讲,ECMAScript 5 旨在和当前的 ECMAScript 3 版本保持向后兼容(以寻求在不同浏览器上更快速的采用),并对开发者提供了更加严格的限制来避免通常的编码陷阱。

严格模式

严格模式的引入,目的在于避免 ECMAScript 应用中通常的代码问题。这是通过在单元(脚本或函数)上指定一句话来达到的:

“use strict;”

这句话不会对已有的运行时产生什么影响,但版本是 5 的新运行时就会为整个脚本(如果这句话定义在脚本开头)或者单个函数(如果定义在函数的开头)打开严格模式。这样就允许计划中的既有代码对严格模式和非严格模式的混合使用。那么,严格模式意味着什么呢?

  • 变量在使用前必须声明。换句话说,i=3 这下就是个运行时错误了;需要 var i=3(如果 i 在做作用域里面没有定义过)
  • eval 变成保留字,而从 eval 引入的新变量不再有效,因此 eval(“var i=3”); print(i); 现在会抛出错误。
  • 不再使用八进制;所以 010 就是十,不再是八。
  • 如果 configurable 被设置成 false,delete 就不能使用在参数、函数、变量或者其他属性上。
  • 一般会带来错误的 with 语句,将不再使用,会被认为是语法错误。
  • 函数不再能使用具有相同名称的重复参数。
  • 对象不再能使用具有相同名称的重复属性。
  • arguments 和 caller 变量不再可变。
  • 对全局对象的访问将会是运行时错误。

库扩展

基本库中的其他扩展包括:

  • Date 现在可以支持生成 ISO8601 格式的日期(比如 20091209T12:34:56Z),并可以解析。
  • String 现在有内建的 trim() 方法
  • 新添 JSON 对象包括 parse 和 stringify 方法来支持 JSON 数据的高效生成;就像 eval,但在减少代码时不会带来安全影响。另外,不仅仅可以使用 RFC 4627 中的 JSONObject 和 JSONArray,还可以使用 JSONValue。(RFC 4627 把 JSON-Text 限制成一个对象或者数组)
  • 新添 bind 内建方法,就跟 Prototype 的 bind 方法的语义一样。
  • 数组现在可以支持 indexOf(),map(),filter() 和 reduce()。
  • 对象现在有 seal() 方法(防止添加新的属性和删除既有属性)和 freeze() 方法(使得所有属性变成只读,同时防止新添属性或删除属性)
  • Object.keys() 可以列出所有能列举的对象属性。
  • Object.getOwnPropertyNames() 可以列出所有能列举和不能列举的属性。
  • Object.getPrototypeof() 可以得到指定对象的 prototype 属性。

总结

新增的标准 JSON 对象解析机制和严格模式将会让开发者受益良多,使得转化成 Prototype 和其他扩展库需要的更小型库成为可能。从 JSON 流解析出 ISO 日期现在要变得比以前方便很多,而且看起来会成为将来日期表示事实上的标准。最后,因为这次是向后兼容的,并从 Prototype 这样既有库获得灵感,开发者和 web 浏览器很有可能在不久将来会为 JavaScript 带来新的特性。

2009-12-12 23:1310503
用户头像

发布了 127 篇内容, 共 46.3 次阅读, 收获喜欢 5 次。

关注

评论

发布
暂无评论
发现更多内容

经常会采坑的javascript原型应试题

loveX001

JavaScript 前端

社招前端二面面试题总结

loveX001

JavaScript 前端

低代码选型,论协同开发的重要性

葡萄城技术团队

建议收藏!数据可视化大屏设计必备步骤

葡萄城技术团队

LeetCode题解:89.格雷编码,归纳法,详细注释

Lee Chen

JavaScript LeetCode

ChatGPT专题 | 万字长文解析!复现和使用GPT-3/ChatGPT,你所应该知道的

工赋开发者社区

每日一题之请描述Vue组件渲染流程

bb_xiaxia1998

Vue 前端

2023前端二面vue面试题

bb_xiaxia1998

Vue 前端

2023年Java面试正确姿势(1000+面试题附答案解析)

Java编程日记

Java 架构 后端 java程序员 java面试

React循环DOM时为什么需要添加key

beifeng1996

前端 React

工业数字孪生:西门子工业网络与设备虚拟调试案例(TIA+MCD+SINETPLAN)

工赋开发者社区

和狂飙的 ChatGPT 聊聊软件开发的现在与未来

极狐GitLab

DevOps 研发效能 DevSecOps 极狐GitLab ChatGPT

React的useLayoutEffect和useEffect执行时机有什么不同

beifeng1996

前端 React

行业分析| OA系统中的实时通讯

anyRTC开发者

音视频 远程办公 视频会议 视频通话 OA

如何实现文件高速传输,推荐镭速高速文件传输解决方案

镭速

逃离同质化,OPPO折叠屏正在笃定远一点的未来

脑极体

OPPO 折叠屏

IoT企业物联网平台,从设备端到云端业务系统全链路开发实战——实践类

阿里云AIoT

数据库 监控 物联网 存储 消息中间件

NFTScan x TiDB丨一栈式 HTAP 数据库为 Web3 数据服务提供毫秒级多维查询

PingCAP

TiDB

阿里云云通信风控系统的架构与实践

阿里云CloudImagine

云计算 云通信

美团前端常见面试题整理

loveX001

JavaScript 前端

前端react面试题(边面边更)

beifeng1996

前端 React

每日一题之Vue的异步更新实现原理是怎样的?

bb_xiaxia1998

Vue 前端

最佳的18个JAVASCRIPT前端开发框架和库

2D3D前端可视化开发

web前端 Javascript框架 前端开发框架 webgl库 javascript库

测试开发 | Dubbo 接口测试技术,测试开发进阶必备(附源码)

霍格沃兹测试开发学社

0经验拿下大厂年薪30万Offer,我的面试求职之路(含面试题)~

霍格沃兹测试开发学社

深入理解JS作用域链与执行上下文

loveX001

JavaScript

百度前端一面高频react面试题指南

beifeng1996

前端 React

用ChatGPT优化AI绘画提示词的探索

Baihai IDP

人工智能 AI AIGC ChatGPT

IoT物联网设备端硬件上云技术方案详解——实践类

阿里云AIoT

物联网 存储 开发工具 数据采集 传感器

用户属性-MQTT 5.0新特性

EMQ映云科技

物联网 IoT mqtt 企业号 2 月 PK 榜 用户属性

如何使用 Kubernetes 实现应用程序的弹性伸缩

API7.ai 技术团队

Prometheus api 网关 APISIX Serverless Kubernetes

ECMAScript 5正式发布_Java_Alex Blewitt_InfoQ精选文章