JavaScript基础与特性:解释性语言、预编译与隐式类型转换

需积分: 10 1 下载量 40 浏览量 更新于2024-07-17 收藏 26.66MB DOCX 举报
JavaScript(JS)笔记 本篇笔记主要围绕JavaScript编程语言的核心特性展开,涵盖了其作为解释性语言、单线程模型(与ECMAScript、DOM和BOM的关系)、变量和函数声明提升、预编译过程以及数据类型的处理。让我们逐一深入探讨。 **1. 单线程与ECMAScript、DOM和BOM** JavaScript是一种单线程的语言,这意味着所有的代码都在同一时间执行,不会同时处理多个任务。然而,通过浏览器提供的DOM(文档对象模型)和BOM(浏览器对象模型),它能够模拟并发效果,实际上是异步操作。全局变量如`window.a = 123`展示了变量在全局作用域中的声明与浏览器对象的关系。 **2. 函数声明和变量提升** JavaScript的函数声明会被提升到逻辑代码的顶部,无论它们在何处定义。同样,变量声明也具有提升机制,但只有变量声明,没有赋值会被提升。这可能导致意外的行为,因此在编写JavaScript代码时需注意声明的位置。 **3. 预编译过程** 在函数执行前,JavaScript引擎会进行预编译步骤: - 创建活动对象(AO)用于存储变量和函数。 - 找到形参和变量声明,并在AO中为它们设置默认值undefined。 - 统一实参和形参。 - 将函数声明绑定到函数体。 **4. 数据类型与运算符** - 逻辑运算符`&&`和`||`在遇到第一个符合条件的值后停止计算,返回该值。`typeof`用于检查变量类型,即使是未声明的变量也会返回`undefined`,而非抛错。 - 显式类型转换方法,如`Number()`、`parseInt()`、`parseFloat()`等,用于强制转换数据类型,需要注意某些特殊情况下可能得到`NaN`。 - 隐式类型转换涉及`isNaN()`、算术运算符、字符串连接符和比较运算符,它们会在运算前进行类型转换,例如`isNan()`会先将混合类型转换为数字。 **5. 闭包** 闭包是JavaScript的一个重要概念,当内部函数被外部引用时,形成了闭包。这种特性允许函数访问并操作其外部作用域的变量,即使函数执行完毕后,这些变量仍然存在。闭包常常用于实现私有变量和封装功能。 总结起来,这篇JS笔记涵盖了基础语法特性,从单线程模型到变量提升,再到数据类型处理和闭包,这些都是理解和编写高效、健壮JavaScript代码的基础。熟练掌握这些知识点,将有助于你在JavaScript编程道路上更进一步。