接下来应该是BOM和HTML5了,但是鉴于ECMAScript5相对于ECMAScript3的新变化比较多,而且这些变化也非常的有意思,因此在这篇文章中再将我认为的有意思的变化(并非全部变化)集中整理一下,但这里只是列举,不具体展开。
一、语法变化
1、关键字和保留字
在ES3中,使用关键字做标识符会导致“Identifier Expected ”错误,而使用保留字做标识符可能会也可能不会导致相同的错误,具体取决于特定的引擎。在ES5中,关键字和保留字虽然不能作为标识符 使用,但可以作为对象的属性名。在ES5中的关键字和保留字中,新增了let和yield。为了保证最大的兼容性,不管是ES3还是ES5中的关键字和保留字,都不要作为标识符使用。
2、属性特性
ES5允许使用用户定义的属性描述来覆盖给定属性的enumerable、configurable、writable、get、set等属性了。具体方法是使用定义在Object对象上的静态函数。
3、严格模式
最大的语法变化,就是引入了严格模式,可以通过语句"use strict"; 来开启严格模式,在代码顶部添加整个脚本启用严格模式,在函数内部添加则只对该函数启用严格模式。严格模式下主要的变化有:
(1)使用变量前必须先定义,即不允许隐式的全局变量
(2)不使用八进制数据
(3)不使用with语句
(4)eval
A、不能使用eval作为标识符,因此不能把变量或函数命名为eval
B、外部不能访问在eval()函数中定义的变量
(5)arguments
A、不能使用arguments作为标识符
B、不能修改作为函数内部对象的arguments,因此形式参数和arguments之间不再有同步变化
C、不能访问arguments.callee
D、ES5中定义了arguments.caller属性,它的值始终是undefined,主要用于区分arguments.caller和函数的caller,但是不能在严格模式下访问
(6)函数
A、函数中不能出现两个同名的形式参数
B、不能给函数的caller属性赋值
C、未指定环境对象而调用函数,this值不会指向window,而是undefined
(7)对象
A、对象中不能出现两个同名的属性
B、修改一个特性[[writable]]为false的属性时,会抛出异常,而不是静默失败,同样的使用delete删除特性[[configurable]]为false的属性时也会抛出异常
(8)delete
不能使用delete删除显示声明的变量和函数
二、内建对象的变化
1、Object对象
(1)继承相关方法:create()、getPrototypeOf()
(2)属性相关方法:defineProperty()、defineProperties()、getOwnPropertyDescriptor()、getOwnPropertyNames()、keys()
(3)防篡改方法:preventExtensions()、isExtensible()、seal()、isSealed()、freeze()、isFrozen()
2、Function对象
(1)添加了bind()方法。
(2)规范化了一个函数对象的属性caller,用于指向调用当前函数的函数的引用。
(3)prototype是不可枚举的
3、Array对象
(1)判断方法:添加了静态方法Array.isArray(obj)用于判断obj是否为一个Array对象的实例。
(2)索引方法:添加了两个用于查找指定项索引的方法indexOf()和lastIndexOf()。查找时使用全等(===)进行匹配。
(3)迭代方法:添加了every()、some()、forEach()、map()、filter()方法。
(4)缩小方法:添加了reduce()和reduceRight()方法。
4、String对象
添加了trim()方法。
5、JSON对象
添加了原生JSON内建对象。
6、Date对象
添加了Date.now()、Date.prototype.toJSON()等方法。
7、RegExp对象
在ES3中,使用正则表达式字面量时共享一个RegExp实例,而在ES5中,每次使用正则表达式字面量时都要创建新的RegExp实例,就像使用RegExp构造函数一样。
0
0
JavaScript高级程序设计(第3版)学习笔记13 ECMAScript5新特性_基础知识
相关文章
JavaScript模板字面量:理解ES5与ES6+中的字符串格式化
深入理解JavaScript字符串处理:从ES5到ES6模板字面量
JavaScript中正则表达式分组匹配的实现:Python对应逻辑转换指南
javascript中bind是什么意思
React 中 setState 为何看似“延迟更新”?真相与最佳实践详解
java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门AI工具
相关专题
本专题全面整理了Yandex搜索引擎的官方入口信息,涵盖国际版与俄罗斯版官网访问方式、网页版直达入口及免登录使用说明,帮助用户快速、安全地进入Yandex官网,高效使用其搜索与相关服务。
200
2026.02.11
本专题系统整理了虫虫漫画官网及网页版最新入口,涵盖免登录观看、正版漫画全集在线阅读方式,并汇总稳定可用的访问渠道,帮助用户快速找到虫虫漫画官方页面,轻松在线阅读各类热门漫画内容。
40
2026.02.11
本专题面向后端与运维开发者,系统讲解 Docker 容器化技术在实际项目中的应用。内容涵盖 Docker 镜像构建、容器运行机制、Docker Compose 多服务编排,以及在 DevOps 流程中的持续集成与持续部署实践。通过真实场景演示,帮助开发者实现应用的快速部署、环境一致性与运维自动化。
4
2026.02.11
本专题聚焦 Rust 语言的异步编程模型,深入讲解 async/await 机制与 Tokio 运行时的核心原理。内容包括异步任务调度、Future 执行模型、并发安全、网络 IO 编程以及高并发场景下的性能优化。通过实战示例,帮助开发者使用 Rust 构建高性能、低延迟的后端服务与网络应用。
1
2026.02.11
本专题面向 Java 后端开发者,系统讲解如何基于 Spring Boot 与 MyBatis Plus 构建高效、规范的企业级应用。内容涵盖项目架构设计、数据访问层封装、通用 CRUD 实现、分页与条件查询、代码生成器以及常见性能优化方案。通过完整实战案例,帮助开发者提升后端开发效率,减少重复代码,快速交付稳定可维护的业务系统。
6
2026.02.11
本专题汇总了包子漫画官网和网页版入口,提供最新章节抢先看方法、正版免费阅读指南,以及稳定访问方式,帮助用户快速直达包子漫画页面,无广告畅享全集漫画内容。
159
2026.02.10
本专题汇总了MC.JS官网入口和网页版快速畅玩方法,提供免安装访问、不同版本(1.8.8、1.12.8)在线体验指南,以及正版网页端操作说明,帮助玩家轻松进入MC.JS世界,实现即时畅玩与高效体验。
89
2026.02.10
本专题汇总了谷歌邮箱网页版的最新登录入口和注册方法,详细提供官方账号快速访问方式、网页版操作教程及安全登录技巧,帮助用户轻松管理Gmail邮箱账户,实现高效、安全的邮箱使用体验。
78
2026.02.10
热门下载
相关下载
精品课程
共28课时 | 4.2万人学习
共37课时 | 1.8万人学习
共10课时 | 0.8万人学习
最新文章

