全文共3525字,预计学习时长12分钟
图源:pexels
一切都从对象开始。
对象,即我们相互交流的一个载体,有其属性和方法。对象是面向对象编程的核心,不仅用于JavaScript,而且还适用于Java、C语言、C 等。不再考虑单个变量和函数,而选择自给型的对象。
以下是在讨论面向对象编程(OOP)时最常用到的概念:
· 对象,属性,方法
· 类
· 封装
· 抽象
· 复用/继承
· 多态性
· 关联
· 聚合
· 组合
1. 对象,属性,方法
1.1 对象字面量(Objectliteral)
在大括号中设置属性,从而在JavaScript中创建一个新对象。对象字面量属性值可以是任何数据类型,如函数字面量、数组、字符串、数字或布尔值。
下面创建一个命名图书的对象,其属性包括作者、出版年份、标题和方法。
— summary.
constbook = {title: "Hippie",author: "Paulo Coelho",year: "2018"}
对象创建完成后,可以使用点记法获取值。例如,可以使用book.title.获取标题的值,还可以使用方括号book[‘title’]访问属性。
1.2 对象构造函数(Objectconstructor)
对象构造函数与常规函数相同。每次创建对象时都会用到。可将其与新关键字一起使用。当需要创建具有相同属性和方法的多个对象时,对象构造函数非常有用。
constbook = {
title: "Hippie",author: "Paulo Coelho",year: "2018"}const book1 = {title: "The Alchemist",author: "Paulo Coelho",year: "1988",}
如果要创建多个书籍(book)对象,必须为每本书复制代码。可以继续创建 book对象,但这有点麻烦——不过对象构造函数有助于再次使用对象字面量。
functionBook(title, author, year) {this.title = title;this.author = author;this.year = year;}const book1 = new Book ('Hippie', 'Paulo Coelho',
'2018');
console.log(book1);
> Book {title: "Hippie",author: "Paulo Coelho",year: "2018"}// if we want to create more than onebook just we call
function book with new keyword.const book2
= new Book ('TheAlchemist', 'Paulo Coelho', '1988');
book1 和 book2创建 Book的实例并将其分配给变量。想知道一个对象是否是另一个对象的实例。可以用instanceof。
book1 instanceof Book
> true
1.3 Object.create()方法
JavaScript中的每个对象都将从主对象创建。任何时候使用大写字母“O”时,指的都是主对象。我们可以在console控制台中打印主对象。主对象有很多方法,下面来看object.create()方法。
Object.create()创建法使用现有对象作为原型来创建新对象。基本语法如下:
Object.create(proto,[propertiesObject])
proto是新建对象的原型。 propertiesObject是一个可选项。
下面举个简单的例子:
constBook = {summary : function() {console.log(`${this.title} iswritten by ${this.author}.`)}}const book1 = Object.create(Book);book1.author = "Paulo Coelho";book1.title = "Hippie";console.log(book1.summary());> Hippie is written by Paulo Coelho.
以上的例子创建了一个原始对象book1,并为作者和标题赋值。可以看到原始对象中的汇总函数:
下面将Object.create() 方法进行详细介绍。
2. 类
类不是对象,它是对象的蓝本,是特殊函数。可以使用函数的表达式和声明来定义函数,也可以这样定义类。蓝本可用来表示对象的数量。
可以使用类的关键字和名称。语法与Java相似。
类语法是使用面向对象编程和管理原型的一个好途径:
let Book= function(name) {this.name = name}let newBook = function(name) {Book.call(this, name)} newBook.prototype = Object.create(Book.prototype);const book1 = new newBook("The Alchemist");
此例使用了ES6类语法:
classBook {constructor(name) {this.name = name}}class newBook extends Book {constructor(name) {super(name);}}const book1 = new newBook("The Alchemist");
类语法是语法糖(syntactical sugar)—而场景背后它仍然使用基于原型的模型。类是函数,而函数是JavaScript中的对象。
classBook {constructor(title, author){this.title = title;this.author = author;}summary() {console.log(`${this.title} writtenby ${this.author}`);}}const book1 = new Book("", "");
console.log(typeof Book);> "function"console.log(typeof book1);> "object"
3. 封装(Encapsulation)
封装意为隐藏信息或数据。指对象在不向外部使用者透露任何执行细节的情况下执行其功能。换句话说,就是其私有变量只对当前函数可见,而对全局范围或其他函数不可访问。
constBook = function(t, a) {let title = t;let author = a;return {summary : function() {console.log(`${title} written by${author}.`);}}}const book1 = new Book('Hippie', 'Paulo Coelho');
book1.summary();> Hippie written by Paulo Coelho.
在上面的代码中,标题和作者只在函数Book 的范围内可见,方法summary对Book的使用者可见。所以书名和作者被封装在Book中。
4. 抽象
抽象意为实现隐藏。它是一种隐藏实现细节的方法,只向使用者显示基本特性。换句话说,它隐藏了不相关的细节,只显示了必须对外部世界显示的。缺乏抽象会导致代码出现可维护性问题。
constBook = function(getTitle, getAuthor) {
// Private variables / propertieslet title = getTitle;let author = getAuthor;// Publicmethodthis.giveTitle = function() {return title;}// Private methodconst summary = function() {return `${title} written by${author}.`}// Public method that has access toprivate method.this.giveSummary = function() {return summary()}}const book1 = new Book('Hippie', 'Paulo Coelho');
book1.giveTitle();> "Hippie"book1.summary();> Uncaught TypeError: book1.summary is not a
functionbook1.giveSummary();> "Hippie written by Paulo Coelho."
5. 复用/继承
JavaScript继承是一种机制,允许我们使用现有的类创建一个新类。也就是子类继承父类的所有属性和行为。
一般来说,JavaScript不是一种基于类的语言。关键字“类”是在ES6中引入的,但它是语法糖,JavaScript仍然是基于原型的。在JavaScript中,继承是通过使用原型来实现的。这种模式称为行为委托模式或原型继承。
同样可以通过book例子来体现:
functionBook(title, author, year) {
this.title = title;this.author = author;this.year = year;this.summary = function() {console.log(`${this.title} iswritten by ${this.author}.`)}}const book1 = new Book ('Hippie', 'Paulo Coelho', '2018');
const book2 = newBook ('The Alchemist', 'Paulo Coelho',
'1988');
原型继承
对于Book的每个实例,我们都在为基类中的方法重建内存。这些方法必须在所有实例之间共享 — 不应特定于个别实例中。图中的原型是:
letCorebook = function(title) {
this.title = title}Corebook.prototype.title = function() {console.log(`name of the book is${this.title}`);}Corebook.prototype.summary = function(author) {console.log(`${this.title} is writtenby ${this.author}`);}let Book = function(title, author) {Corebook.call(this, title, author)}Book.prototype = Object.create(Corebook.prototype);
let book1
= new Book('TheAlchemist', 'Paulo Coelho');book1.title();> name of the book is The Alchemistbook1.summary();> The Alchemist is written by Paulo Coelho
在上面的代码中,Book 的实例有一个原型的副本,能够链接到Book的原型,而Book的原型又链接到Corebook的原型。
6. 多态
在不同的对象上使用同一方法,并让每个对象具有自己的表现形式或形态的能力,称为多态。
letbook1 = function () {}
book1.prototype.summary = function() {return "summary of book1"}let book2 = function() {}book2.prototype = Object.create(book1.prototype);book2.prototype.summary = function() {return "summary of book2"}let book3 = function() {}book3.prototype = Object.create(book1.prototype);book3.prototype.summary = function() {return "summary of book3"}var books = [new book1(), new book2(), new book3()];books.forEach(function(book){console.log(book.summary());});> summary of book1> summary of book2> summary of book3
对象之间的关系将由关联、聚合和组合定义。
7. 关联
关联是两个或多个对象之间的关系。每个对象都是独立的。换句话说,关联定义了对象之间的多重性:一对一、一对多、多对一、多对多。
functionBook(title, author) {this.title = title;this.author = author;}
const book1 = new Book ('Hippie', 'Paulo Coelho');
const book2 = new Book ('TheAlchemist',
'Paulo Coelho');
book2.multiplicity
= book1
book1 赋值于book2的属性多样化,显示对象book1 和 book2之间的关系。两者都可以独立添加和删除。
8. 聚合
聚合是关联的特例。在两个对象之间的关系中,一个对象可能比另一个更重要。换句话说,当一个对象比另一个拥有更多的所有权时,这就是聚合。对象所有者通常称为聚合,被所有者称为组件。聚合又叫“Has-a”关系。
functionBook(title, author) {
this.title = title;this.author = author;}
const book1 = new Book ('Hippie', 'Paulo Coelho');
const book2 = new Book ('TheAlchemist', 'Paulo Coelho');
let publication = {"name": "new publicationInc","books": []}publication.books.push(book1);publication.books.push(book2);
book1 和 book2 被添加到对象publication下设的books中。如果在book1和book2 运行之后删除publication,则 Book和 publication 都将独立运行。
9. 组合
组合是聚合的一种特殊情况。一个对象包含另一个对象,并且被包含的对象脱离后无法生存。
let Book= {
"title": "TheAlchemist","author": "PauloCoelho","publication": {"name": "newpublication Inc","address":"chennai"}}
这里属性publication与 Book 对象有严格的限制,publication不能没有Book对象。如果Book的id被删除,则publication也将被删除。
重组合轻继承
继承指一个对象基于另一个对象的情况。例如,book1继承了标题、作者和结语等书籍的属性和方法,所以它建立了book1 is-a Book关系。
组合是收集单一对象并将它们组合起来构建更复杂的对象。为构建book1,需要一些方法,比如纸和笔。因此book1 has-a paper and a pen关系随之出现。
constgetTitle = (data) => ({
title : () => console.log(`title :${data.title}`)});const getAuthor = (data) => ({author : () => console.log(`author:${data.author}`)});const getSummary = () => ({summary :() => console.log(`booksummary need to
update.`)});const Book = (title, author) => {const data = {title,author}return Object.assign({},getTitle(data),getAuthor(data),getSummary())}let book1 = Book('The Alchemist', 'Paulo Coelho');
book1.title();> "title : The Alchemist"
留言点赞关注
我们一起分享AI学习与发展的干货
如转载,请后台留言,遵守转载规范
javascript进阶面向对象编程(使用JavaScript进行面向对象编程的指南)
2024-11-06 02:57:46 作者:烈酒还在烧 网址:https://m.xinb2b.cn/sport/dwd216368.html
- 斗罗大陆发布会肖战吴宣仪(曝斗罗2的剧本已经准备完毕)
- 2024-11-06曝斗罗2的剧本已经准备完毕前言:有趣的灵魂,超高的颜值,这就是肖战,一个以作品说话的流量明星!新年之初,肖战以一部《斗罗大陆》开启了他牛气冲天的一年顶级IP,顶级流量,外加完美演技,《斗罗大陆》顺利拿下来20亿的播放量!可以说。
- 12月国内旅行地推荐(12月一定要去的10个国内旅行地)
- 2024-11-0612月一定要去的10个国内旅行地人们常说“春有百花秋有月,夏有凉风冬有雪”转眼间,2019年的最后的一个月,就要来临了这一年的时间,你应该让自己邂逅一些美好,得到一份奖励不如来一次冬的旅行,给自己一个圆满的2019年今天小编就为大家。
- 四种必备好物推荐(首次公开让你从头白到脚的好物)
- 2024-11-06首次公开让你从头白到脚的好物让你从头白到脚的好物!原来白这么简单啊这些国货真的越来越牛了不仅便宜,而且个个都好用啊上海硫磺皂(后背干干净净了)安牧丹熊果苷水乳(皮肤透亮白皙了)澳芙茶树植物泥膜面膜(黑头少了)宝中宝脲素霜(关节白。
- 莲藕蒸肉饼怎么做好吃(怎样做莲藕蒸肉饼)
- 2024-11-06怎样做莲藕蒸肉饼食材:猪肉糜250克、葱花适量、莲藕1节、盐(调味料)1/2茶匙、料酒(调味料)1茶匙、姜片(调味料)数片、酱油(调味料)1茶匙莲藕去皮,先切碎,再切成茸姜片用少量的水浸泡数分钟,取走姜片,用姜片水与。
- 巩汉林现状采访(你到底得罪了谁)
- 2024-11-06你到底得罪了谁都说文体不分家,可前段时间,文艺界和体育圈却来了一场的“冯巩之争”,高潮迭起,看点十足乍一看,还以为是冯巩老师出了什么事;仔细一瞧,才知道是小品演员巩汉林和国足队员冯潇霆的论战起因并不复杂,是巩汉林在。
- 火影忍者干柿鬼鲛强吗(干柿鬼鲛火影里的硬汉)
- 2024-11-06干柿鬼鲛火影里的硬汉说起干柿鬼鲛,相信喜欢看《火影忍者》的不少朋友都对他印象深刻吧?!他成长在具有血雾之村之称的雾隐村,一路靠着杀戮和毫无意义地执行任务存活下来后来,干柿鬼鲛受到宇智波带土的邀请,加入了晓组织,成为组。
- 长春新批学校(长春热门学校入学审核详情来了)
- 2024-11-06长春热门学校入学审核详情来了信息审核这块还是在如火如荼的进行着,有的家长已经接到通知开始着手准备相关材料,而有的家长还在苦苦等待……不要急!靠谱的八卦小编已经把最最最新的通知信息审核详情的学校整理出来啦,快来夸夸我~(以下为热心。
- 长柄雨伞安检可以托运吗(多功能雨伞带安全锤)
- 2024-11-06多功能雨伞带安全锤晴天挡太阳,雨天能遮雨,出门在外,雨伞似乎必不可少恰逢广州这些天持续降雨,相当部分旅客都会随身携带雨伞但是,李先生的雨伞却被告知不能随身携带原来,他的伞除了能当雨伞使用,还有其它隐藏功能!4月20日下。
- 南瓜有没有好的吃法(食材让温润的南瓜温暖你的胃)
- 2024-11-06食材让温润的南瓜温暖你的胃甜味的美食有很多但是敢大张旗鼓的说自己是香甜的就不多尤其是那种从视觉到嗅觉再到味觉都感觉甜腻腻的就更是凤毛麟角了烤南瓜就敢金灿灿的表面就好像有糖液析出来飘散过来的全部是软软糯糯的气味香中透着甜筷子轻轻。
- 华灯初上夜未央全文
- 2024-11-06华灯初上夜未央全文1.《怜音赋》华灯初上,夜未央歌舞笙箫,古道旁纸醉金迷,秦淮殇墨色生香,皆虚妄月影归人,眼迷惘桂树桥旁,自相望姣月之下,都成双2.华灯初上,夜未央:是指夜晚的照明灯亮起的时间不长,夜色还未结束央:结束。
- 三八妇女节送花会怎样(三八女神节教你如何送花)
- 2024-11-06三八女神节教你如何送花你还在送给妈妈传统包装的康乃馨,送给爱人传统包装的百合吗?不得不说,太土啦!送花嘛,好看才是王道相比以花语为目的的单品花束,好看且花材丰富的混搭花束更受宠特别一些的花材、好看协调的花材搭配、新款式的包。
- 虞书欣表情太真实了 刘真是娇柔清新
- 2024-11-06虞书欣表情太真实了 刘真是娇柔清新《青春有你2》里的选手是不是虞书欣最有热度?叔看评论说大家第一集似乎都不怎么喜欢她,觉得她太做作太嗲了但是风评转变很快,又播了两集之后,大家又觉得在“冰清玉洁”四人组的衬托下,虞书欣还是挺真实、可爱的。