什么是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的更多相关文章

  1. javascript高级程序设计--笔记01

    概述 JavaScript的实现包含三个部分: 1  核心(ECMAScript)   提供核心语言功能 2  文档对象模型(DOM)  一套提供了访问以及操作网页内容的API 3  浏览器对象模型( ...

  2. 阅读摘录《javascript 高级程序设计》01

    前言: 因为工作需要,所以开始主攻前台JS方面的技术.在以前的工作中,使用过这门脚本语言.但是都是比较凌乱的,用到什么学什么,只是为了实现业务,而去使用. 不会考虑到代码优化,封装对象等.今次特意借了 ...

  3. javascript高级编程笔记01(基本概念)

    1.在html中使用JavaScript 1.  <script> 元素 <script>定义了下列6个属性: async:可选,异步下载外部脚本文件. charset:可选, ...

  4. JavaScript高级程序设计笔记(一)

    ---恢复内容开始--- 前三章为基础知识,为了方便以后查看,所以比较啰嗦.这里对函数的基本操作没有记录. 1.JavaScript的实现 虽然 JavaScript 和 ECMAScript 通常都 ...

  5. JavaScript高级程序设计笔记之面向对象

    说起面向对象,大部分程序员首先会想到 类 .通过类可以创建许多具有共同属性以及方法的实例或者说对象.但是JavaScript并没有类的概念,而且在JavaScript中几乎一切皆对象,问题来了,Jav ...

  6. Javascript高级程序设计——在HTML中使用Javascript

    <script>元素 向HTML页面中插入Javascript的主要方法,就是使用<script>元素,<script>元素有六个属性: async:可选.表示应该 ...

  7. javascript事件小结(事件处理程序方式)--javascript高级程序设计笔记

    1.事件流:描述的是从页面中接收事件的顺序. 2.事件冒泡:IE的事件流叫做事件冒泡,即事件开始从具体的元素(文档中嵌套层次最深的那个节点)接收,然后逐级向上传播到不具体的节点(文档). 3.事件捕获 ...

  8. JavaScript高级程序设计笔记 事件冒泡和事件捕获

    1.事件冒泡 要理解事件冒泡,就得先知道事件流.事件流描述的是从页面接收事件的顺序,比如如下的代码: <body> <div> click me! </div> & ...

  9. <javascript高级程序设计>笔记

    1.要讲一个值转换成其对应的Boolean类型 ,可以调用转型函数Boolean(). var message=“hello world!”; var messageAsBoolean=Boolean ...

  10. javaScript高级程序设计笔记 2

    Undefinde Null Boolean Number String    基本类型 Object    引用类型 只有引用类型才能动态的添加属性 赋值基本类型和引用类型也不相同,复制的基本类型的 ...

随机推荐

  1. 利用IPV6随时访问家中影音Jellyfin

    本文章主要记录通过ipv6实现家庭影音中心在互联网上的访问. 之前很多方案都是通过第三方进行内网穿透,实际体验不是很好.目前ipv6发展迅速,完全可以取代这种以ipv4为中心的内网资源外网访问的方式. ...

  2. React-Chat移动端聊天实例|react18 hooks仿微信App聊天界面

    基于react18+react-vant+zustand仿微信手机端聊天室ReactChat. react18-chat 一款使用最新react18.x hooks.zustand搭配react-va ...

  3. 面霸的自我修养:synchronized专题

    王有志,一个分享硬核Java技术的互金摸鱼侠 加入Java人的提桶跑路群:共同富裕的Java人 今天是<面霸的自我修养>的第3弹,内容是Java并发编程中至关重要的关键字synchroni ...

  4. 《深入理解Java虚拟机》读书笔记:方法调用

      方法调用并不等同于方法执行,方法调用阶段唯一的任务就是确定被调用方法的版本(即调用哪一个方法),暂时还不涉及方法内部的具体运行过程.在程序运行时,进行方法调用是最普遍.最频繁的操作,但前面已经讲过 ...

  5. 《Kali渗透基础》12. 无线渗透(二)

    @ 目录 1:无线协议栈 1.1:ifconfig 1.2:iwconfig 1.3:iw 1.4:iwlist 2:无线网卡配置 2.1:查看无线网卡 2.2:查看信道频率 2.3:扫描附近 AP ...

  6. 弹性数据库连接池探活策略调研(三)——DBCP

    前言 在之前的文章中,我们介绍了弹性数据库连接失效的背景,并探讨了HikariCP.Druid连接池探活策略的相关内容.在本文中,我们将会继续探讨另一个线上常用的连接池--DBCP,并为您介绍如何在使 ...

  7. C#应用程序的多语言方案 - 开源研究系列文章

    今天讲讲笔者自创的C#应用程序多语言的方案. 这个多语言方案,主要是对应用的窗体及其控件进行检索,然后根据控件的名称进行在语言字典里进行检索获取到对应的语言文本进行赋值显示的.笔者对网上的多语言方案进 ...

  8. Netty+WebSocket整合STOMP协议

    1.STOMP协议简介 常用的WebSocket协议定义了两种传输信息类型:文本信息和二进制信息.类型虽然被确定,但是他们的传输体是没有规定的,也就是说传输体可以自定义成什么样的数据格式都行,只要客户 ...

  9. Solution -「HNOI 2010」城市建设

    Description Link. 修改边权的动态 MST. Solution 讲清楚点. 修改边权的 MST,考虑对时间分治.设我们当前操作的操作区间是 \([l,r]\),直接暴力找 MST 是不 ...

  10. 6. 用Rust手把手编写一个wmproxy(代理,内网穿透等), 通讯协议源码解读篇

    用Rust手把手编写一个wmproxy(代理,内网穿透等), 通讯协议源码解读篇 项目 ++wmproxy++ gite: https://gitee.com/tickbh/wmproxy githu ...