JavaScript高级程序设计笔记01 什么是JavaScript
什么是JavaScript
1995年问世。
最初在客户端处理某些基本的验证。
名字:Mocha -> LiveScript -> JavaScript
ECMAScript脚本语言标准:ECMA-262(TC39,第39技术委员会)
完整的的JavaScript包含:
- 核心ECMAScript
- 文档对象模型DOM
- 浏览器对象模型BOM
宿主环境提供ECMAScript的基准实现和与环境自身交互必需的扩展。
ECMA-262定义了什么:
语法 | 类型 | 语句 | 关键字 | 保留字 | 操作符 | 全局对象
版本更迭
第1版:本质上与JavaScript1.1相同,支持Unicode标准,对象与平台无关
第2版:一些编校
第3版(!!):更新了字符串处理、错误定义和数值输出。另外还增加了对正则表达式、新的控制语句、try/catch异常处理的支持,等
第4版(×):强类型变量、新语句和数据结构、真正的类和经典的继承,以及操作数据的新手段
第5版(3.1!!!):厘清第3版的歧义,增加对JSON的支持、方便继承和高级属性定义的方法、增加严格模式
第6版(2015.6!!!!):支持类、模块、迭代器、生成器、箭头函数、期约(Promise)、反射、代理和众多新的数据类型(Map、Set等)
第7版(2016.6):少量语法层面的增强,如Array.prototype.includes和指数操作符
第8版(2017.6):增加了异步函数(async/await)、SharedArrayBuffer及Atomics API,以及Object.values()/Object.entries()/Object.getOwnPropertyDescriptors()和字符串填充方法(?),明确支持对象字面量最后的逗号。
第9版(2018.6):异步迭代、剩余和扩展属性、一组新的正则表达式特性、Promise finally(),以及模板字面量修订
第10版(2019.6):增加了Array.prototype.flat()/flatMap()、String.prototype.trimStart()/trimEnd()、Object.fromEntries()方法,以及Symbol.prototype.description属性,明确定义了Function.prototype.toString()的返回值并固定了Array.prototype.sort()的顺序。解决了与JSON字符串兼容的问题,并定义了catch子句的可选绑定(?)
ECMAScript符合性:
必须满足的条件
- 支持ECMA-262中描述的所有“类型、值、对象、属性、函数,以及程序语法与语义”;
- 支持Unicode字符
浏览器支持
| 浏览器 | DOM Level | ECMAScript符合性 |
|---|---|---|
| IE5.5~8 | DOM Level1 | ES3 |
| IE9 | ES5(部分) | |
| IE10-11 | ES5 | |
| Edge12+ | ES6 | |
| Safari6~8 | ES5 | |
| Safari9+ | ES6 | |
| Chrome49+ | ES6 | |
| FireFox45+ | ES6 | |
| iOS Safari 9.2+ | ES6 |
DOM
一个应用编程接口(API),用于在HTML中使用扩展的XML。DOM将整个页面抽象为一组分层节点。
动态HTML:不刷新页面而修改页面外观和内容。
DOM级别
DOM Level1(1998):DOM Core和DOM HTML两个模块。目标:映射文档结构
DOM Core:提供一种映射XML文档,从而方便访问和操作文档任意部分的方式;DOM HTML扩展了Core并增加了特定于HTML的对象和方法。
DOM Level2:增加了对鼠标和用户界面事件、范围、遍历的支持,通过对象接口支持了CSS。DOM Core也被扩展以包含对XML命名空间的支持。
新增模块:
- DOM视图:描述追踪文档不同视图的接口。(如应用CSS样式前后的文档)
- DOM事件:描述事件及事件处理的接口
- DOM样式:描述处理元素CSS样式的接口
- DOM遍历和范围:描述遍历和操作DOM树的接口
DOM Level3:进一步扩展了DOM,增加了以统一的方式加载和保存文档的方法(DOM Load and Save的新模块中),还有验证文档的方法(DOM Validation)。DOM Core扩展以支持所有XML1.0的特性,包括XML Infoset、XPath和XML Base。
DOM4(DOM Living Standard):新增的内容包括替代Mutation Events的Mutation Observers。
L1+L2(部分)+L3(部分):Opera 9 | Safari2+ | iOS Safari 3.2+ | Chrome 1+ | FF 1+
其他DOM
基于XML的,增加了自己独有的DOM方法和接口:
- SVG(可伸缩矢量图,Scalable Vector Graphics)
- MathML(数学标记语言,Mathematics Markup Language)
- SMIL(同步多媒体集成语言,Synchronized Multimedia Integration Language)
BOM
可以操控浏览器显式页面之外的部分。
唯一一个没有相关标准的JavaScript实现。<——HTML5
主要针对浏览器窗口和子窗口,通常包括特定于浏览器的扩展:
- 弹出新浏览器窗口的能力(window.open)
- 移动、缩放和关闭浏览器窗口的能力
- navigator对象,提供关于浏览器的详尽信息
- location对象,提供浏览器加载页面的详尽信息
- screen对象,提供关于用户屏幕分辨率的详尽信息
- performance对象,提供浏览器内存占用、导航行为和时间统计的详尽信息
- 对cookie的支持
- 其他自定义对象,如XMLHttpRequest和IE的ActiveXObject
多数浏览器对JavaScript的支持,指的是实现ECMAScript和DOM的程度。
JavaScript高级程序设计笔记01 什么是JavaScript的更多相关文章
- javascript高级程序设计--笔记01
概述 JavaScript的实现包含三个部分: 1 核心(ECMAScript) 提供核心语言功能 2 文档对象模型(DOM) 一套提供了访问以及操作网页内容的API 3 浏览器对象模型( ...
- 阅读摘录《javascript 高级程序设计》01
前言: 因为工作需要,所以开始主攻前台JS方面的技术.在以前的工作中,使用过这门脚本语言.但是都是比较凌乱的,用到什么学什么,只是为了实现业务,而去使用. 不会考虑到代码优化,封装对象等.今次特意借了 ...
- javascript高级编程笔记01(基本概念)
1.在html中使用JavaScript 1. <script> 元素 <script>定义了下列6个属性: async:可选,异步下载外部脚本文件. charset:可选, ...
- JavaScript高级程序设计笔记(一)
---恢复内容开始--- 前三章为基础知识,为了方便以后查看,所以比较啰嗦.这里对函数的基本操作没有记录. 1.JavaScript的实现 虽然 JavaScript 和 ECMAScript 通常都 ...
- JavaScript高级程序设计笔记之面向对象
说起面向对象,大部分程序员首先会想到 类 .通过类可以创建许多具有共同属性以及方法的实例或者说对象.但是JavaScript并没有类的概念,而且在JavaScript中几乎一切皆对象,问题来了,Jav ...
- Javascript高级程序设计——在HTML中使用Javascript
<script>元素 向HTML页面中插入Javascript的主要方法,就是使用<script>元素,<script>元素有六个属性: async:可选.表示应该 ...
- javascript事件小结(事件处理程序方式)--javascript高级程序设计笔记
1.事件流:描述的是从页面中接收事件的顺序. 2.事件冒泡:IE的事件流叫做事件冒泡,即事件开始从具体的元素(文档中嵌套层次最深的那个节点)接收,然后逐级向上传播到不具体的节点(文档). 3.事件捕获 ...
- JavaScript高级程序设计笔记 事件冒泡和事件捕获
1.事件冒泡 要理解事件冒泡,就得先知道事件流.事件流描述的是从页面接收事件的顺序,比如如下的代码: <body> <div> click me! </div> & ...
- <javascript高级程序设计>笔记
1.要讲一个值转换成其对应的Boolean类型 ,可以调用转型函数Boolean(). var message=“hello world!”; var messageAsBoolean=Boolean ...
- javaScript高级程序设计笔记 2
Undefinde Null Boolean Number String 基本类型 Object 引用类型 只有引用类型才能动态的添加属性 赋值基本类型和引用类型也不相同,复制的基本类型的 ...
随机推荐
- HTML超文本标记语言1
一.简介-HTML 1.什么是HTML?? 首先,HTML是WWW的描述语言,由Tim Berners-lee提出. HTML是用于描述网页的一种语言 html是指超文本标记语言(HyperText ...
- 1. 通俗易懂的Redis基础
通俗易懂的Redis基础教程(基于CentOS 7) 目录 通俗易懂的Redis基础教程(基于CentOS 7) 1 Redis是什么 1.1 NoSQL概念 1.2 NoSQL与SQL比较 1.3 ...
- 【Nacos篇】Nacos基本操作及配置
官方文档:https://nacos.io/zh-cn/docs/v2/ecology/use-nacos-with-spring-cloud.html 前置条件:SpringCloud脚手架 单机模 ...
- 【pandas小技巧】--列值的映射
映射列值是指将一个列中的某些特定值映射为另外一些值,常用于数据清洗和转换. 使用映射列值的场景有很多,以下是几种常见的场景: 将字符串类型的列中的某些值映射为数字.例如,将"男"和 ...
- vlak
2023-7-14 题目 luogu题目传送门 题目描述 Nina 和 Emilija 正在玩一个特殊的游戏.这个游戏是在一张最开始为空白的纸上进行的.在每一个人的行动回合内,这个人会在这张纸上当前的 ...
- 质量管理 | QC、QA、QM,去QA化与降本增效
现在国内职业的质量管理都是从 CMMI 和 ISO 质量体系演化过来的,但是能做真正的质量管理的公司很少.质量管理的 QC 偏测试,对最终的产品负责:QA 偏过程,从过程把控质量:QM 偏体系,类似于 ...
- plt.rcParams运行时修改全局配置参数
plt.rcParams简单介绍 plt.rcParams即 "运行时配置参数"("runtime configuration parameters"),是运行 ...
- Python 潮流周刊#18:Flask、Streamlit、Polars 的学习教程
你好,我是猫哥.这里每周分享优质的 Python.AI 及通用技术内容,大部分为英文.标题取自其中三则分享,不代表全部内容都是该主题,特此声明. 本周刊由 Python猫 出品,精心筛选国内外的 25 ...
- 代码随想录算法训练营第二十八天| 93.复原IP地址 78.子集 90.子集II
93.复原IP地址 卡哥建议:本期本来是很有难度的,不过 大家做完 分割回文串 之后,本题就容易很多了 题目链接/文章讲解:https://programmercarl.com/0093.%E5% ...
- QA|selenium在send_keys时报错dict object has no attribute ''|UI自动化测试
Q:selenium在send_keys时报错dict object has no attribute 'send_keys',如下图 增加了print(type(e1))发现确实是字典类型,怪了,按 ...