- JavaScript 菜鸟教程
- JavaScript 教程
- Javascript - 概述
- Javascript - 功能
- 在浏览器中启用 JavaScript
- JavaScript - 放置在 HTML 文件中
- JavaScript - 语法
- JavaScript - Hello World 程序
- JavaScript - Console.log()方法
- JavaScript - 注释
- JavaScript - 变量
- JavaScript - let 语句
- JavaScript - 常量
- JavaScript - 数据类型
- JavaScript - 类型转换
- JavaScript - 严格模式
- JavaScript - 保留关键字
- JavaScript 运算符
- JavaScript - 运算符
- JavaScript - 算术运算符
- JavaScript - 比较运算符
- JavaScript - 逻辑运算符
- JavaScript - 按位运算符
- JavaScript - 赋值运算符
- JavaScript - 条件运算符
- JavaScript - typeof 运算符
- JavaScript - Nullish 合并运算符
- JavaScript - Delete 运算符
- JavaScript - 逗号运算符
- JavaScript - 分组运算符
- JavaScript - Yield 运算符
- JavaScript - Spread 运算符
- JavaScript - 幂运算符
- JavaScript - 运算符优先级
- JavaScript 控制流
- JavaScript - if...else 语句
- JavaScript - While 循环
- JavaScript - For 循环
- JavaScript - For...in 循环
- JavaScript - For...of 循环
- JavaScript - 循环控制
- JavaScript - Break 语句
- JavaScript - Continue 语句
- JavaScript - Switch Case 语句
- JavaScript - 用户定义的迭代器
- JavaScript 函数
- JavaScript - 函数
- JavaScript - 函数表达式
- JavaScript - 函数参数
- JavaScript - 默认参数
- JavaScript - Function() 构造函数
- JavaScript - 函数提升
- JavaScript - 自调用函数
- JavaScript - 箭头函数
- JavaScript - 函数调用
- JavaScript - 函数 call() 方法
- JavaScript - 函数 apply() 方法
- JavaScript - 函数 bind() 方法
- JavaScript - 闭包
- JavaScript - 变量范围
- JavaScript - 全局变量
- JavaScript - 智能函数参数
- JavaScript 对象
- JavaScript - Number 对象
- JavaScript - 布尔对象
- JavaScript - String 对象
- JavaScript - Array 对象
- JavaScript - 日期对象
- JavaScript - DataView 对象
- JavaScript - 处理程序
- JavaScript - math 对象
- JavaScript - 正则表达式
- JavaScript - Symbol 对象
- JavaScript - Set(集)对象
- JavaScript - WeakSet 对象
- JavaScript - Maps (地图) 对象
- JavaScript - WeakMap 对象
- JavaScript - Iterables 对象
- JavaScript - Reflect 对象
- JavaScript - TypedArray 对象
- JavaScript - 模板文本
- JavaScript - tagged 模板
- 面向对象的 JavaScript
- JavaScript - 对象概述
- JavaScript - 类(Classes)
- JavaScript - 对象属性
- JavaScript - 对象方法
- JavaScript - Static(静态)方法
- JavaScript - display(显示)对象
- JavaScript - 对象访问器
- JavaScript - 对象构造函数
- JavaScript - 原生原型
- JavaScript - ES5 对象方法
- JavaScript - Encapsulation(封装)
- JavaScript - Inheritance(继承)
- JavaScript - Abstraction(抽象)
- JavaScript - Polymorphism(多态性)
- JavaScript - 解构赋值
- JavaScript - 对象解构
- JavaScript - 数组解构
- JavaScript - 嵌套解构
- JavaScript - 可选链接
- JavaScript - 全局对象
- JavaScript - Mixin
- JavaScript - Proxies(代理)
- JavaScript 版本
- JavaScript - 历史
- JavaScript - 版本
- JavaScript - ES5
- JavaScript cookies
- JavaScript - Cookies
- JavaScript - Cookie 属性
- JavaScript - 删除 Cookie
- JavaScript 浏览器 BOM
- JavaScript - 浏览器对象模型
- JavaScript - Window 对象
- JavaScript - Document 对象
- JavaScript - Screen 对象
- JavaScript - History 对象
- JavaScript - navigator 对象
- JavaScript - Location 对象
- JavaScript - Console 对象
- JavaScript Web API
- JavaScript - Web API
- JavaScript - history API( 历史 API)
- JavaScript - Storage API(存储 API)
- JavaScript - Forms API(表单 API)
- JavaScript - Worker API
- JavaScript - Fetch API (获取 API)
- JavaScript - Geolocation API (地理位置 API)
- JavaScript 事件
- JavaScript - Events (事件简介)
- JavaScript - DOM 事件
- JavaScript - addEventListener()
- JavaScript - 鼠标事件
- JavaScript - 键盘事件
- JavaScript - 表单事件
- JavaScript - 窗口/文档事件
- JavaScript - 事件委派
- JavaScript - 事件冒泡
- JavaScript - 事件捕获
- JavaScript - 自定义事件
- JavaScript 错误处理
- JavaScript - 错误和异常处理
- JavaScript - try...catch 语句
- JavaScript - 调试
- JavaScript - 自定义错误
- JavaScript - 扩展错误
- JavaScript 重要关键词
- JavaScript - this 关键字
- JavaScript - void 关键字
- JavaScript - new 关键字
- JavaScript - var 关键字
- JavaScript HTML DOM
- JavaScript - 文档对象模型或 DOM
- JavaScript - DOM 方法
- JavaScript - DOM 文档
- JavaScript - DOM 元素
- JavaScript - DOM 表单
- JavaScript - 更改 HTML
- JavaScript - 更改 CSS
- JavaScript - DOM 动画
- JavaScript - DOM 导航
- JavaScript - DOM 集合
- JavaScript - DOM 节点列表
- JavaScript 杂项
- JavaScript - Ajax
- JavaScript - 异步迭代
- JavaScript - Atomics 对象 (原子对象)
- JavaScript - Rest 参数
- JavaScript - 页面重定向
- JavaScript - 对话框
- JavaScript - 页面打印
- JavaScript - 表单验证
- JavaScript - 动画
- JavaScript - 多媒体
- JavaScript - Image Map(图像映射)
- JavaScript - 浏览器兼容性
- JavaScript - JSON
- JavaScript - 多行字符串
- JavaScript - 日期格式
- JavaScript - 获取日期方法
- JavaScript - 设置日期方法
- JavaScript - 模块
- JavaScript - 动态导入
- JavaScript - BigInt 数据类型
- JavaScript - Blob
- JavaScript - Unicode
- JavaScript - 浅层复制
- JavaScript - 调用堆栈
- JavaScript - 引用类型
- JavaScript - IndexedDB
- JavaScript - 点击劫持攻击
- JavaScript - Currying (局部套用)
- JavaScript - 图形
- JavaScript - Canvas
- JavaScript - Debouncing (防抖)
- JavaScript - 性能
- JavaScript - 样式指南
- JavaScript - 内置函数
Javascript - 概述
什么是 JavaScript?
JavaScript 是一种动态计算机编程语言。它是轻量级的,最常用作网页的一部分,其实现允许客户端脚本与用户交互并制作动态页面。它是一种具有面向对象功能的解释型编程语言。
JavaScript 是一种单线程编程语言,我们可以用于客户端或服务器端开发。它是一种动态类型的编程语言,这意味着我们在编写 JavaScript 代码时不关心变量数据类型。此外,它还包含控制语句、运算符和对象,如数组、数学、数据等。
JavaScript 最初被称为 LiveScript,但 Netscape 将其名称更改为 JavaScript,可能是因为 Java 引起了人们的兴奋。JavaScript 于 1995 年首次出现在 Netscape 2.0 中,名称为 LiveScript。该语言的通用核心已嵌入到 Netscape 和其他 Web 浏览器中。
ECMA-262 规范定义了核心 JavaScript 语言的标准版本。
- JavaScript 是一种轻量级的解释型编程语言。
- 专为创建以网络为中心的应用程序而设计。
- 与 Java 互补并集成。
- 与 HTML 互补并集成。
- 开放和跨平台
JavaScript 的历史
JavaScript 由 Netscape Communications Corporation 的计算机科学家和程序员 Brendan Eich 开发。JavaScript 的最初名称是“Mocha”。之后,它更改为“LiveScript”,然后是“JavaScript”。
1996 年至 1997 年间,欧洲计算机制造商协会 (ECMA) 对 JavaScript 进行了标准化。之后,已经完成了 JavaScript 的 3 次修订。
在 ES5 (2009) 中,引入了 Node.js 以使用 JavaScript 作为服务器端语言。ES6 (2015) 是 JavaScript 的重要修订版,在 JavaScript 中引入了高级功能。
目前,JavaScript 已达到 ES14 版本。ES14 (ECMAScript 2023) 第 14 版,于 2023 年 6 月发布。
客户端 JavaScript
客户端 JavaScript 是该语言最常见的形式。该脚本应包含在 HTML 文档中或由 HTML 文档引用,以便浏览器解释代码。
这意味着网页不必是静态 HTML,而是可以包含与用户交互、控制浏览器和动态创建 HTML 内容的程序。
与传统的 CGI 服务器端脚本相比,JavaScript 客户端机制具有许多优势。例如,您可以使用 JavaScript 来检查用户是否在表单字段中输入了有效的电子邮件地址。
JavaScript 代码在用户提交表单时执行,只有当所有条目都有效时,它们才会被提交到 Web 服务器。
JavaScript 可用于捕获用户启动的事件,例如按钮单击、链接导航以及用户明示或隐式启动的其他操作。
流行的用于 JavaScript 开发的客户端库是 ReactJS、NextJS、Vue JS、Angular JS 等。
服务器端 JavaScript
在早期,JavaScript 用于前端开发,以向 HTML 页面添加行为。自 2009 年以来,JavaScript 还被用作服务器端编程语言,用于构建可扩展和动态的 Web 应用程序。
Node.js 是使用 JavaScript 构建应用程序服务器的最佳和最流行的 JavaScript 运行时环境之一。使用 Node.js,我们可以在浏览器外部执行 JavaScript 代码并管理服务器任务。服务器任务可以是与数据库、APIS、文件处理的交互,也可以是网络通信。由于 Node.js 的事件驱动架构,它比其他服务器端编程语言更快。
JavaScript 的优点
使用JavaScript的优点是 -
- 减少服务器交互 - 您可以在将页面发送到服务器之前验证用户输入。这样可以节省服务器流量,这意味着服务器上的负载更少。
- 对访问者的即时反馈 - 他们不必等待页面重新加载以查看他们是否忘记输入某些内容。
- 增加交互性 - 您可以创建当用户使用鼠标悬停在它们上面或通过键盘激活它们时做出反应的界面。
- 更丰富的界面 - 您可以使用JavaScript来包含拖放组件和滑块等项目,以为您的网站访问者提供丰富的界面。
JavaScript 的局限性
我们不能将 JavaScript 视为一种成熟的编程语言。它缺少以下重要功能:
- 客户端 JavaScript 不允许读取或写入文件。出于安全原因,我们保留了此内容。
- JavaScript 不能用于网络应用程序,因为没有这样的支持。
- JavaScript 没有任何多线程功能。
同样,JavaScript 是一种轻量级的解释型编程语言,它允许您将交互性构建到原本静态的 HTML 页面中。
命令式 JavaScript 与声明式 JavaScript
命令式和声明式是一种编程范式,JavaScript 遵循两者。
- 命令式JavaScript - 在命令式JavaScript中,我们按照代码描述获取输出的步骤来编写代码。因此,我们关注的是代码执行流程和输出。例如,要对所有数组元素求和,如果我们为 loop 编写代码,它会解释每个步骤以获取总和。
- 声明式JavaScript - 在声明式JavaScript中,我们不需要担心执行流程,但我们应该在最后得到正确的输出。例如,我们使用内置的 array.reduce() 方法来获取数组元素的总和。在这里,我们不关心 reduce() 方法如何在库中实现。
JavaScript 开发工具
JavaScript 的主要优势之一是它不需要昂贵的开发工具。您可以从简单的文本编辑器(例如记事本)开始。由于它是 Web 浏览器上下文中的一种解释型语言,因此您甚至不需要购买编译器。
这里有各种免费工具,它们在使用 JavaScript 开发应用程序时可能会有所帮助。
- Visual Studio Code(VS Code) - VS Code是大多数开发人员用来编写JavaScript代码的代码编辑器。它功能丰富,并包含各种扩展,可以提高任何开发人员的生产力。
- Chrome 开发工具 - 程序员可以使用 Chrome 开发工具来调试 JavaScript 代码。但是,他们可以使用任何浏览器的调试工具,因为大多数浏览器都附带它。
上述 2 个工具提高了开发人员编写代码的生产力。此外,您可以使用其他工具,例如 Git 进行版本控制、Webpack 来构建您的应用程序等。
JavaScript 版本?
2015 年,JavaScript 的 ES6 版本发布,并进行了重大改进,包括面向对象的概念、匿名函数、模板文字等。2023 年 6 月,JavaScript 的第 14 个版本 ES14(ECMAScript 2023)发布。