JavaScript是OOP语言吗?
我知道,这个话题已经被讨论过太多次了。但是,它总是被不断地提及。每当Java或C#或任何其他OOP语言的开发人员与JavaScript接触时,这些开发人员都会抱怨连连。他们说,用JavaScript工作简直是一团乱,没有类型,结构不合理,有些怪异,对象支持不给力,它绝对不是OOP语言。
其中有一些抱怨可能可以接受,但还有一些则是偏见,例如说JavaScript没有类型因而它不是OOP语言的言论。关于后面一点,在出口论断之前,你应该问自己:是什么使编程语言成为面向对象的编程语言?
什么是OOP?
OOP模式没有正式的标准规范。没有一个技术文档定义了什么是OOP,什么不是OOP。OOP定义主要基于早期研究人员,如Kristen Nygaard, Alan Kays, William Cook等人发表的论文中的常识。已经有很多人尝试定义OOP以及一个可广泛接受的定义来对编程语言进行分类,因为面向对象基于两个要求:
通过对象建模问题的能力。
支持一些准许模块化和代码重用的原则。
为了满足第一个要求,这种语言必须使开发人员能够使用对象来描述现实并定义对象之间的关系,如下所示:
关联:对象引用另一个独立对象的能力。
聚合:对象嵌入一个或多个独立对象的能力。
组合:对象嵌入一个或多个依赖对象的能力。
通常,如果语言支持以下原则,则能满足第二个要求:
封装:专注于数据和操纵代码的单一实体,并隐藏其内部细节的能力。
继承:一个对象从一个或多个其他对象获取某些或所有要素的机制。
多态:根据数据类型或结构不同地处理对象的能力。
满足这些要求的语言我们通常将其归类为为面向对象的。
JavaScript和OOP
所以现在我们知道OOP语言应该是什么样子的了。那么,我们可以证明JavaScript是一种OOP语言吗?咱们试试吧。
我们知道,JavaScript对象支持关联,聚合和组合的能力并不强劲。请看以下代码:
var johnSmith = { firstName: "John", lastName: "Smith", address: { //Composition street: "123 Duncannon Street", city: "London", country: "United Kingdom" } }; var nickSmith = { firstName: "Nick", lastName: "Smith", address: { //Composition street: "321 Oxford Street", city: "London", country: "United Kingdom" } }; johnSmith.parent = nickSmith; //Association var company = { name: "ACME Inc.", employees: [] }; //Aggregation company.employees.push(johnSmith); company.employees.push(nickSmith);
在上面的代码中,你可以找到一个组合(address属性)的示例,一个关联(parent属性)的示例和一个聚合(employees属性)的示例。
至于封装,JavaScript对象是支持数据和函数的实体,但它们没有高级的本地支持来隐藏内部细节。JavaScript对象不关心隐私。如果不谨慎的话,所有的属性和方法都可以公开访问。但是,我们可以应用若干技术来定义对象的内部状态,并保护对象以防外部访问:使用getter和setter来利用闭包。
通过所谓的原型继承,JavaScript在基本层中支持继承。即使有些开发人员认为它有点简单,但JavaScript的继承机制是完全有效的,并允许你得到与大多数公认的OOP语言相同的结果。任凭你怎么想,JavaScript有一个机制,通过这个机制“一个对象从一个或多个其他对象获取一些或所有的功能”,这就是继承。
有多态性的挑战似乎更加困难,因为许多人把这个概念与数据类型联系起来。实际上,多态性涉及编程语言的许多方面,并且不仅仅是与OOP语言有关。通常它涉及诸如泛型、重载和结构子类型等条目。所有这些对于一种“简单”和弱类型的语言——JavaScript——来说似乎不堪重负。然而事实并非如此:在JavaScript中,我们可以通过若干方式实现不同类型的多态,也许我们在不知不觉中已经做过很多次了。
没有类的OOP
“好吧,但话说回来,JavaScript没有类。”
许多开发人员认为JavaScript缺乏类的概念,而没有将JavaScript视为一种真正的面向对象的语言,因为它不强制符合OOP原则。
但是,我们可以看到,在非正式的定义中,并没有明确提及类。诚然,对象需要特性和原理。但类并非真正的要求,只是有时,类是一种抽象具有公共属性的对象集的简便方法而已。因此,即使一种语言的支持对象没有类,它也可以是面向对象的语言,例如JavaScript。
此外,OOP原则的目的旨在得到支持。为了在语言中进行编程,OOP原则不应该是强制规定的。开发人员可以选择使用允许他创建面向对象代码的构造,也可以选择不使用。许多人批评JavaScript是因为开发人员可以编写违反OOP原则的代码。但这只是程序员的选择,而不是语言的限制。其他的编程语言也会发生这样的事情,如C ++。
所以,我们可以得出这样一个结论,缺乏抽象类并允许开发人员自由使用或不使用支持OOP原理的功能,并非认定JavaScript是OOP语言的真正障碍
以上是JavaScript是OOP语言吗?的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

众所周知,iPhone是最人性化的电子产品之一,其中一个原因是它可以轻松地根据您的喜好进行个性化设置。在个性化设置中,您可以更改语言,这与您在设置iPhone时选择的语言不同。如果您对多种语言熟悉,或者您的iPhone语言设置错误,您可以按照我们下面解释的方法进行更改。如何更改iPhone的语言[3种方法]iOS允许用户在iPhone上自由切换首选语言,以适应不同的需求。您可以更改与Siri的交互语言,方便与语音助手进行沟通。同时,在使用本地键盘时,您可以轻松地在多种语言之间切换,提高输入效率。

人脸检测识别技术已经是一个比较成熟且应用广泛的技术。而目前最为广泛的互联网应用语言非JS莫属,在Web前端实现人脸检测识别相比后端的人脸识别有优势也有弱势。优势包括减少网络交互、实时识别,大大缩短了用户等待时间,提高了用户体验;弱势是:受到模型大小限制,其中准确率也有限。如何在web端使用js实现人脸检测呢?为了实现Web端人脸识别,需要熟悉相关的编程语言和技术,如JavaScript、HTML、CSS、WebRTC等。同时还需要掌握相关的计算机视觉和人工智能技术。值得注意的是,由于Web端的计

有时候我们再刚刚入手安装好电脑系统之后发现系统时英文的,遇到这种情况我们就需要把电脑的语言改成中文,那么win10系统里面该怎么把电脑的语言改成中文呢,现在就给大家带来具体的操作方法。win10电脑语言怎么改成中文1、打开电脑点击左下角的开始按键。2、点击左侧的设置选项。3、打开的页面选择“时间和语言”4、打开后,再点击左侧的“语言”5、在这里就可以设置你要的电脑语言。

随着互联网金融的迅速发展,股票投资已经成为了越来越多人的选择。而在股票交易中,蜡烛图是一种常用的技术分析方法,它能够显示股票价格的变化趋势,帮助投资者做出更加精准的决策。本文将通过介绍PHP和JS的开发技巧,带领读者了解如何绘制股票蜡烛图,并提供具体的代码示例。一、了解股票蜡烛图在介绍如何绘制股票蜡烛图之前,我们首先需要了解一下什么是蜡烛图。蜡烛图是由日本人

基于大模型的持续优化,LLM智能体——这些强大的算法实体已经展现出解决复杂多步骤推理任务的潜力。从自然语言处理到深度学习,LLM智能体正逐渐成为研究和工业界的焦点,它们不仅能理解和生成人类语言,还能在多样的环境中制定策略、执行任务,甚至使用API调用和编码来构建解决方案。在这种背景下,AgentQuest框架的提出具有里程碑意义,它不仅仅是一个LLM智能体的评估和进步提供了一个模块化的基准测试平台,而且通过其易于扩展的API,为研究人员提供了一个强大的工具,以更细粒度地跟踪和改进这些智能体的性能

JavaScript教程:如何获取HTTP状态码,需要具体代码示例前言:在Web开发中,经常会涉及到与服务器进行数据交互的场景。在与服务器进行通信时,我们经常需要获取返回的HTTP状态码来判断操作是否成功,根据不同的状态码来进行相应的处理。本篇文章将教你如何使用JavaScript获取HTTP状态码,并提供一些实用的代码示例。使用XMLHttpRequest

js和vue的关系:1、JS作为Web开发基石;2、Vue.js作为前端框架的崛起;3、JS与Vue的互补关系;4、JS与Vue的实践应用。

一、背景重构工作中,代码规范:B端前端开发过程中开发者总会面临重复开发的痛点,很多CRUD页面的元素模块基本相似,但仍需手动开发,将时间花在简单的元素搭建上,降低了业务需求的开发效率,同时因为不同开发者的代码风格不一致,使得迭代时其他人上手成本较高。AI代替简单脑力:AI大模型的不断发展,已经具备简单的理解能力,并可以进行语言到指令的转换。对于基础页面搭建这样的通用指令可满足日常基础页面搭建的需求,提升通用场景业务开发效率。二、生成链路一览B端页面列表、表单、详情都支持生成,链路大概可分为以下几
