为什么要去了解javascript的底层?

简介: 为什么要去了解javascript的底层?

为什么要去了解javascript的底层?

JavaScript的基本数据类型

JavaScript的基本数据类型包括:数字、字符串、布尔值、null、undefined。其中,数字类型可以是整数或浮点数,字符串类型用单引号或双引号表示,布尔值只有true和false两个取值,null表示一个空值,undefined表示一个未定义的值。

在JavaScript底层实现中,每种数据类型都有相应的内部表示方式和操作方法。例如,数字类型在内部使用IEEE 754标准表示,字符串类型使用Unicode字符集表示,布尔值使用1和0表示,null和undefined都是特殊的值。


JavaScript的变量和作用域

JavaScript的变量使用var、let、const等关键字声明,可以存储各种数据类型的值。JavaScript的作用域分为全局作用域和函数作用域,变量的作用域决定了它的可见性和生命周期。


在JavaScript底层实现中,变量和作用域的实现涉及到词法作用域、执行上下文、变量对象等概念。JavaScript引擎会在代码执行前进行编译,生成执行上下文和变量对象,用于存储变量和函数的相关信息。在代码执行时,JavaScript引擎会按照作用域链的顺序查找变量和函数,并进行相应的操作。


JavaScript的函数和闭包

JavaScript的函数是一种特殊的对象,可以作为参数、返回值、变量等使用。JavaScript的函数可以使用function关键字定义,也可以使用箭头函数定义。JavaScript的函数支持闭包,即可以访问外部函数的变量和函数。


在JavaScript底层实现中,函数和闭包的实现涉及到函数对象、作用域链、变量对象等概念。JavaScript的函数对象包括函数代码和函数作用域,函数作用域包含函数的自身作用域和外部作用域。在闭包中,JavaScript引擎会将外部函数的变量和函数保存在闭包中,供内部函数使用。


JavaScript的对象和原型

JavaScript的对象是一种复合数据类型,可以存储多个属性和方法。JavaScript的对象可以使用对象字面量、构造函数、Object.create等方式创建。JavaScript的对象支持原型继承,可以通过原型链实现属性和方法的继承和重写。


在JavaScript底层实现中,对象和原型的实现涉及到对象、原型、构造函数、继承等概念。JavaScript的对象是由构造函数和原型对象组成的,构造函数用于创建对象实例,原型对象用于存储共享的属性和方法。在继承中,JavaScript引擎会按照原型链的顺序查找属性和方法,并进行相应的操作。


JavaScript的事件和异步编程

JavaScript的事件是一种交互方式,可以响应用户的操作和系统的事件。JavaScript的事件可以通过addEventListener、removeEventListener等方法注册和取消。JavaScript的异步编程是一种处理耗时操作和回调函数的方式,可以使用setTimeout、setInterval、Promise、async/await等方法实现。


在JavaScript底层实现中,事件和异步编程的实现涉及到事件队列、事件循环、回调函数等概念。JavaScript的事件队列用于存储事件和回调函数,事件循环用于按照顺序执行事件和回调函数。在异步编程中,JavaScript引擎会将异步操作和回调函数保存在事件队列中,在事件循环时执行相应的操作。


运行机制

从运行层面说,JS是由浏览器或Node.js等JavaScript运行环境提供的解析器、执行器和垃圾回收器。这些底层组件协同工作,使得JavaScript代码可以被解析、执行和管理内存。


解析器是JavaScript的第一步,它将JavaScript代码转换为可执行的计算机指令。解析器会读取代码并将其转换为抽象语法树(AST),然后将AST转换为字节码或机器码,最终让计算机执行。解析器还会检查代码的语法和语义,以确保代码的正确性。


执行器是JavaScript的第二步,它执行由解析器生成的字节码或机器码。执行器会按照代码的顺序执行每一条指令,并将结果存储在内存中。执行器还有一些优化策略,如即时编译(JIT)和预解析(Pre-Parsing),以提高代码的执行效率。


垃圾回收器是JavaScript的第三步,它负责回收不再使用的内存。JavaScript使用自动垃圾回收机制,垃圾回收器会定期扫描内存,找出不再使用的变量和对象,并将它们释放掉,以便其他变量和对象可以使用这些内存空间。垃圾回收器的算法有很多种,如标记清除、引用计数等。


除了解析器、执行器和垃圾回收器,JavaScript底层还有一些特性,如原型继承、闭包、事件循环等。这些特性使得JavaScript成为一门强大的编程语言,并且使得JavaScript在Web应用程序、服务器端应用程序、桌面应用程序等不同领域都得到广泛应用。


单线程执行:JavaScript是单线程执行的,即同一时间只能执行一个任务。这是由于JavaScript的运行时环境决定的,例如浏览器只有一个UI线程。


事件驱动:JavaScript是事件驱动的,即通过监听事件来触发执行相应的代码。例如,点击按钮会触发click事件,从而执行相应的JavaScript代码。


动态类型:JavaScript是一种动态类型语言,即变量的类型可以在运行时动态改变。

原型继承:JavaScript使用原型继承来实现对象之间的继承关系,而不是传统的类继承。这使得JavaScript具有更大的灵活性和可扩展性。


认识和会用JavaScript是第一步,第二步是更好的了解它,了解了JavaScript的底层实现,可以更好地理解JavaScript的特性和行为方式,帮助我们优化代码,提高应用程序的性能和可靠性


相关文章
|
8月前
|
缓存 JavaScript 前端开发
JavaScript核心知识总结(下)一
JavaScript核心知识总结(下)一
|
8月前
|
存储 前端开发 JavaScript
JavaScript核心知识总结(中)二
JavaScript核心知识总结(中)二
|
8月前
|
存储 自然语言处理 JavaScript
JavaScript核心知识总结(中)一
JavaScript核心知识总结(中)一
|
8月前
|
Web App开发 存储 JavaScript
JavaScript核心知识总结(上)
JavaScript核心知识总结(上)
|
8月前
|
JavaScript 前端开发
JavaScript的概念
JavaScript的概念
|
8月前
|
JavaScript 前端开发 应用服务中间件
JavaScript核心知识总结(下)二
JavaScript核心知识总结(下)二
|
8月前
|
JavaScript 前端开发 API
JavaScript由哪部分组成,它们的区别是什么?
JavaScript由哪部分组成,它们的区别是什么?
|
自然语言处理 JavaScript 前端开发
javaScript的底层(详解)
javaScript的底层(详解)
233 0
|
自然语言处理 前端开发 JavaScript
为什么要去了解javascript的底层?如何认识
为什么要去了解javascript的底层?如何认识
125 0
|
存储 自然语言处理 JavaScript
JavaScript基础系列(6):`this`这六种使用方式,你都理解了吗?
执行发现两个this都指向了全局的window.也就是全局执行上下文中的this和函数执行上下文中的this都指向了全局window.所以默认的情况下,在全局中调用一个函数,函数中执行上下文中的this都是指向window对象的。
122 0