您当前的位置:首页 > 电脑百科 > 程序开发 > 语言 > javascript

33 个重要的 JavaScript 概念

时间:2022-12-24 15:49:58  来源:今日头条  作者:程序猿最幽默

了解这33个JAVAScript概念绝对会让你将来的职业生涯受益无穷。

话不多说,直接进入主题!

1. 调用栈


 

调用栈是解释器(如web浏览器中的JavaScript解释器)跟踪其在调用多个函数的脚本中的位置的机制——当前正在运行什么函数以及从函数中又调用了哪些函数等。

2. 原始类型(Primitive Types)


 

除了对象之外的所有类型都定义了不可变的值(即不能更改的值)。例如(不同于C语言),字符串是不可变的。我们将这些类型的值称为“原始值”。

3. 值类型和引用类型


 

分配了非原始值的变量将获得对该值的引用。引用指向对象在内存中的地址。变量实际上并不包含值。

4. 隐式、显式、标称、结构化和鸭子类型


 

类型强制意味着当运算符的操作数是不同的类型时,其中一个将被转换为另一个操作数类型的“等价”值。

5. == 和 === 和 typeof


 

JavaScript有两种看上去相似、但实际大相径庭的方法可用于测试相等性。那就是==和===。

6. 函数作用域、块作用域和词法作用域


 

词法作用域:定义在词法阶段的作用域。是由你在写代码时将变量和块作用域写在哪里来决定的。

函数作用域:属于这个函数的全部变量都可以在整个函数的范围内使用(事实上也可用于嵌套的作用域)。

7. 表达式与语句


 

表达式可以像语句一样工作,这就是我们也有Expression语句的原因。但是,另一方面,语句不能像表达式那样工作。

8. IIFE、模块和命名空间


 

常用的函数编码模式有一个花哨的名字:Immediately-invoked Function Expression(立即调用函数表达式)。或者更广为人知的是被写作IIFE。

9. 消息队列和事件循环


 

问:JavaScript如何异步和单线程?

答:JavaScript语言是单线程的,异步行为不是JavaScript语言本身的一部分,而是构建在浏览器(或编程环境)中的核心JavaScript语言之上,并通过浏览器API访问。

10. setTimeout、setInterval和requestAnimationFrame


 

我们可以决定现在不执行函数,而在以后的某个时间执行。

11. JavaScript引擎


 

在写JS代码有时感觉有点神奇,因为开发人员编写的一系列字符就像魔术一样,在浏览器中变成具体的图像、文字和动作。

这一切都是由JS引擎在背后默默地支持着。

12. 位运算符、类型数组和数组缓冲区


 

好的,从技术上讲,对于计算机来说,一切都归结为1和0。因为计算机不使用数字,也不使用字符或字符串,它只使用二进制数字(位)。即一切都以二进制形式进行存储。然后计算机使用UTF-8等编码将保存的位组合映射到字符、数字或不同的符号(ELI5版本)。

13. DOM和布局树


 

文档对象模型,通常称为DOM,是使网站具有交互性的重要部分。它是一个界面,允许编程语言操纵网站的内容、结构和风格。JavaScript是连接到Inte.NET浏览器DOM的客户端脚本语言。

14. 工厂和类


 

JavaScript是基于原型的语言,意味着可以通过具有克隆和扩展能力的通用对象来共享对象属性和方法。这称为原型继承,与类继承不同。

15. this、call、Apply和bind


 

这些函数对每个JavaScript开发人员都非常重要,因为几乎每个JavaScript库或框架中都会用到。

16.new、Constructor、instanceof和Instances


 

每个JavaScript对象都有一个原型。JavaScript中的所有对象都从其原型继承其方法和属性。

17. 原型继承和原型链


 

JavaScript对于学习基于类的语言(如Java或C++)的开发人员来说有点困惑,因为它是动态的并且本身不提供类实现(class关键字由ES2015引入,但却是语法糖,JavaScript仍然基于原型)。

18. Object.create和Object.assign


 

Object.create方法是在JavaScript中创建新对象的方法之一。

19. map,reduce,filter


 

即使你不知道什么是函数式编程,也可能一直在使用map、filter和reduce。它们非常有用,可帮助编写更清晰的逻辑。

20. 纯函数、函数副作用、状态突变和事件传播


 

我们的许多错误都植根于IO相关、数据突变、带有副作用的代码,然后在代码库中蔓延——从接受用户输入、通过http调用接收意外响应或写入到文件系统。不幸的是,这是一个我们不得不习惯的残酷现实。

21. 闭包


 

闭包是将(封闭的)函数与对其周围状态(词法环境)的引用捆绑在一起的组合。换句话说,闭包使你可以从内部函数访问外部函数的范围。在JavaScript中,每次创建函数的同时都会创建闭包。

22. 高阶函数


 

JavaScript可以接受高阶函数。这种处理高阶函数的能力以及其他特性使JavaScript成为非常适合函数式编程的编程语言之一。

23. 递归


 

可以扩展你对函数式编程的理解。

24. 集合与生成器


 

生成器函数返回Generator对象,同时符合可迭代协议和迭代器协议。

25. Promise


 

Promise对象表示异步操作的最终完成(或失败)及其结果值。

26. async/awAIt


 

async/await是一种可以以更舒适的方式处理Promise的特殊语法。非常容易理解和使用。

27. 数据结构


 

JavaScript每天都在发展。随着React、Angular、Vue、NodeJS、Electron、React Native等框架和平台的快速增长,将JavaScript用于大型应用程序已变得相当普遍。

28. 昂贵的运算和Big O标记法


 

“什么是Big O标记法?”这是一个非常常见的开发面试问题。简而言之就是算法运行时间取决于输入时间的数学表达式,通常谈论最坏的情况。

29. 算法


 

在数学和计算机科学中,算法是有明确定义的指令的有限序列,通常用于解决一类特定问题或执行计算。

30. 继承、多态和代码重用


 

类继承是一个类扩展另一个类的一种方式,因此我们可以在现有基础上创建新功能。

31. 设计模式


 

每个开发人员致力于编写可维护、可读和可重用的代码。随着应用程序变得越来越大,代码结构变得越来越重要。设计模式被证明是解决这一挑战的关键——为特定情况下的常见问题提供组织化的结构。

32. 部分应用、Currying、Compose和Pipe


 

函数组合是一种组合多个简单函数以构建更复杂函数的机制。

33. 干净的代码


 

编写干净、可理解和可维护的代码是每个开发人员都必须掌握的一项技能。



Tags:JavaScript   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
JavaScript的异步编程常见模式
在JavaScript中,异步编程是一种处理长时间运行操作(如网络请求或I/O操作)的常见方式。它允许程序在等待这些操作完成时继续执行其他任务,从而提高应用程序的响应性和性能。JavaS...【详细内容】
2024-04-12  Search: JavaScript  点击:(2)  评论:(0)  加入收藏
17 个你需要知道的 JavaScript 优化技巧
你可能一直在使用JavaScript搞开发,但很多时候你可能对它提供的最新功能并不感冒,尽管这些功能在无需编写额外代码的情况下就可以解决你的问题。作为前端开发人员,我们必须了解...【详细内容】
2024-04-03  Search: JavaScript  点击:(6)  评论:(0)  加入收藏
你不可不知的 15 个 JavaScript 小贴士
在掌握如何编写JavaScript代码之后,那么就进阶到实践——如何真正地解决问题。我们需要更改JS代码使其更简单、更易于阅读,因为这样的程序更易于团队成员之间紧密协...【详细内容】
2024-03-21  Search: JavaScript  点击:(27)  评论:(0)  加入收藏
构建一个通用灵活的JavaScript插件系统?看完你也会!
在软件开发中,插件系统为应用程序提供了巨大的灵活性和可扩展性。它们允许开发者在不修改核心代码的情况下扩展和定制应用程序的功能。本文将详细介绍如何构建一个灵活的Java...【详细内容】
2024-03-20  Search: JavaScript  点击:(20)  评论:(0)  加入收藏
对JavaScript代码压缩有什么好处?
对JavaScript代码进行压缩主要带来以下好处: 减小文件大小:通过移除代码中的空白符、换行符、注释,以及缩短变量名等方式,可以显著减小JavaScript文件的大小。这有助于减少网页...【详细内容】
2024-03-13  Search: JavaScript  点击:(2)  评论:(0)  加入收藏
跨端轻量JavaScript引擎的实现与探索
一、JavaScript 1.JavaScript语言JavaScript是ECMAScript的实现,由ECMA 39(欧洲计算机制造商协会39号技术委员会)负责制定ECMAScript标准。ECMAScript发展史: 2.JavaScript...【详细内容】
2024-03-12  Search: JavaScript  点击:(2)  评论:(0)  加入收藏
面向AI工程的五大JavaScript工具
令许多人惊讶的是,一向在Web开发领域中大放异彩的JavaScript在开发使用大语言模型(LLM)的应用程序方面同样大有价值。我们在本文中将介绍面向AI工程的五大工具,并为希望将LLM...【详细内容】
2024-02-06  Search: JavaScript  点击:(53)  评论:(0)  加入收藏
18个JavaScript技巧:编写简洁高效的代码
本文翻译自 18 JavaScript Tips : You Should Know for Clean and Efficient Code,作者:Shefali, 略有删改。在这篇文章中,我将分享18个JavaScript技巧,以及一些你应该知道的示例...【详细内容】
2024-01-30  Search: JavaScript  点击:(71)  评论:(0)  加入收藏
使用 JavaScript 清理我的 200GB iCloud,有了一个意外发现!
本文作者在综合成本因素之下,决定用 Java 脚本来清理一下自己的 iCloud,结果却有了一个意外发现,即在 iCloud 中上传同一个视频和删除此视频之后,iCloud 的空间并不一致,这到底是...【详细内容】
2024-01-11  Search: JavaScript  点击:(99)  评论:(0)  加入收藏
JavaScript前端框架2024年展望
Angular、Next.js、React和Solid的维护者和创作者们展望2024年,分享了他们计划中的改进。译自2024 Predictions by JavaScript Frontend Framework Maintainers,作者 Loraine...【详细内容】
2024-01-05  Search: JavaScript  点击:(91)  评论:(0)  加入收藏
▌简易百科推荐
JavaScript的异步编程常见模式
在JavaScript中,异步编程是一种处理长时间运行操作(如网络请求或I/O操作)的常见方式。它允许程序在等待这些操作完成时继续执行其他任务,从而提高应用程序的响应性和性能。JavaS...【详细内容】
2024-04-12  靳国梁    Tags:JavaScript   点击:(2)  评论:(0)  加入收藏
17 个你需要知道的 JavaScript 优化技巧
你可能一直在使用JavaScript搞开发,但很多时候你可能对它提供的最新功能并不感冒,尽管这些功能在无需编写额外代码的情况下就可以解决你的问题。作为前端开发人员,我们必须了解...【详细内容】
2024-04-03  前端新世界  微信公众号  Tags:JavaScript   点击:(6)  评论:(0)  加入收藏
你不可不知的 15 个 JavaScript 小贴士
在掌握如何编写JavaScript代码之后,那么就进阶到实践——如何真正地解决问题。我们需要更改JS代码使其更简单、更易于阅读,因为这样的程序更易于团队成员之间紧密协...【详细内容】
2024-03-21  前端新世界  微信公众号  Tags:JavaScript   点击:(27)  评论:(0)  加入收藏
又出新JS运行时了!JS运行时大盘点
Node.js是基于Google V8引擎的JavaScript运行时,以非阻塞I/O和事件驱动架构为特色,实现全栈开发。它跨平台且拥有丰富的生态系统,但也面临安全性、TypeScript支持和性能等挑战...【详细内容】
2024-03-21  前端充电宝  微信公众号  Tags:JS   点击:(26)  评论:(0)  加入收藏
构建一个通用灵活的JavaScript插件系统?看完你也会!
在软件开发中,插件系统为应用程序提供了巨大的灵活性和可扩展性。它们允许开发者在不修改核心代码的情况下扩展和定制应用程序的功能。本文将详细介绍如何构建一个灵活的Java...【详细内容】
2024-03-20  前端历险记  微信公众号  Tags:JavaScript   点击:(20)  评论:(0)  加入收藏
对JavaScript代码压缩有什么好处?
对JavaScript代码进行压缩主要带来以下好处: 减小文件大小:通过移除代码中的空白符、换行符、注释,以及缩短变量名等方式,可以显著减小JavaScript文件的大小。这有助于减少网页...【详细内容】
2024-03-13  WangLiwen    Tags:JavaScript   点击:(2)  评论:(0)  加入收藏
跨端轻量JavaScript引擎的实现与探索
一、JavaScript 1.JavaScript语言JavaScript是ECMAScript的实现,由ECMA 39(欧洲计算机制造商协会39号技术委员会)负责制定ECMAScript标准。ECMAScript发展史: 2.JavaScript...【详细内容】
2024-03-12  京东云开发者    Tags:JavaScript   点击:(2)  评论:(0)  加入收藏
面向AI工程的五大JavaScript工具
令许多人惊讶的是,一向在Web开发领域中大放异彩的JavaScript在开发使用大语言模型(LLM)的应用程序方面同样大有价值。我们在本文中将介绍面向AI工程的五大工具,并为希望将LLM...【详细内容】
2024-02-06    51CTO  Tags:JavaScript   点击:(53)  评论:(0)  加入收藏
JS小知识,使用这6个小技巧,避免过多的使用 if 语句
最近在重构我的代码时,我注意到早期的代码使用了太多的 if 语句,达到了我以前从未见过的程度。这就是为什么我认为分享这些可以帮助我们避免使用过多 if 语句的简单技巧很重要...【详细内容】
2024-01-30  前端达人  今日头条  Tags:JS   点击:(58)  评论:(0)  加入收藏
18个JavaScript技巧:编写简洁高效的代码
本文翻译自 18 JavaScript Tips : You Should Know for Clean and Efficient Code,作者:Shefali, 略有删改。在这篇文章中,我将分享18个JavaScript技巧,以及一些你应该知道的示例...【详细内容】
2024-01-30  南城大前端  微信公众号  Tags:JavaScript   点击:(71)  评论:(0)  加入收藏
站内最新
站内热门
站内头条