JavaScript的所有数据都可以看成对象,那是不是我们已经在使用面向对象编程了呢?

当然不是。如果我们只使用Number、Array、string以及基本的{...}定义的对象,还无法发挥出面向对象编程的威力。
JavaScript的面向对象编程和大多数其他语言如Java、C#的面向对象编程都不太一样。如果你熟悉Java或C#,很好,你一定明白面向对象的两个基本概念:
1.类:类是对象的类型模板,例如,定义Student类来表示学生,类本身是一种类型,Student表示学生类型,但不表示任何具体的某个学生;
2.实例:实例是根据类创建的对象,例如,根据Student类可以创建出xiaoming、xiaohong、xiaojun等多个实例,每个实例表示一个具体的学生,他们全都属于Student类型。
所以,类和实例是大多数面向对象编程语言的基本概念。
不过,在JavaScript中,这个概念需要改一改。JavaScript不区分类和实例的概念,而是通过原型(prototype)来实现面向对象编程。
原型是指当我们想要创建xiaoming这个具体的学生时,我们并没有一个Student类型可用。那怎么办?恰好有这么一个现成的对象:
var robot = {
name: 'Robot',
height: 1.6,
run: function () {
console.log(this.name + ' is running...');
}
};
我们看这个robot对象有名字,有身高,还会跑,有点像小明,干脆就根据它来“创建”小明得了!
于是我们把它改名为Student,然后创建出xiaoming:
var Student = {
name: 'Robot',
height: 1.2,
run: function () {
console.log(this.name + ' is running...');
}
};
var xiaoming = {
name: '小明'
};
xiaoming.__proto__ = Student;
注意最后一行代码把xiaoming的原型指向了对象Student,看上去xiaoming仿佛是从Student继承下来的:
xiaoming.name; // '小明' xiaoming.run(); // 小明 is running...
xiaoming有自己的name属性,但并没有定义run()方法。不过,由于小明是从Student继承而来,只要Student有run()方法,xiaoming也可以调用:
JavaScript的原型链和Java的Class区别就在,它没有“Class”的概念,所有对象都是实例,所谓继承关系不过是把一个对象的原型指向另一个对象而已。
如果你把xiaoming的原型指向其他对象:
var Bird = {
fly: function () {
console.log(this.name + ' is flying...');
}
};
xiaoming.__proto__ = Bird;
现在xiaoming已经无法run()了,他已经变成了一只鸟:
xiaoming.fly(); // 小明 is flying...
在JavaScrip代码运行时期,你可以把xiaoming从Student变成Bird,或者变成任何对象。
请注意,上述代码仅用于演示目的。在编写JavaScript代码时,不要直接用obj.__proto__去改变一个对象的原型,并且,低版本的IE也无法使用__proto__。Object.create()方法可以传入一个原型对象,并创建一个基于该原型的新对象,但是新对象什么属性都没有,因此,我们可以编写一个函数来创建xiaoming:
// 原型对象:
var Student = {
name: 'Robot',
height: 1.2,
run: function () {
console.log(this.name + ' is running...');
}
};
function createStudent(name) {
// 基于Student原型创建一个新对象:
var s = Object.create(Student);
// 初始化新对象:
s.name = name;
return s;
}
var xiaoming = createStudent('小明');
xiaoming.run(); // 小明 is running...
xiaoming.__proto__ === Student; // true
# js
# 面向对象
# js面向对象实现canvas制作彩虹球喷枪效果
# 归纳下js面向对象的几种常见写法总结
# JavaScript面向对象编写购物车功能
# JS实现简单面向对象的颜色选择器实例
# js面向对象的写法
# js实现对ajax请求面向对象的封装
# 小明
# 是从
# 创建一个
# 基本概念
# 自己的
# 都是
# 如果你
# 很好
# 是一种
# 就在
# 一只
# 你可以
# 那是
# 多个
# 不太
# 还会
# 是指
# 而来
# 把它
相关文章:
制作网站公司那家好,网络公司是做什么的?
个人摄影网站制作流程,摄影爱好者都去什么网站?
简单实现Android文件上传
专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?
建站OpenVZ教程与优化策略:配置指南与性能提升
建站主机选购指南:核心配置与性价比推荐解析
如何用西部建站助手快速创建专业网站?
免费制作小说封面的网站有哪些,怎么接网站批量的封面单?
香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化
如何在阿里云部署织梦网站?
如何选择PHP开源工具快速搭建网站?
建站之星安装提示数据库无法连接如何解决?
ui设计制作网站有哪些,手机UI设计网址吗?
php8.4新语法match怎么用_php8.4match表达式替代switch【方法】
专业网站制作服务公司,有哪些网站可以免费发布招聘信息?
文字头像制作网站推荐软件,醒图能自动配文字吗?
如何在橙子建站上传落地页?操作指南详解
定制建站哪家更专业可靠?推荐榜单揭晓
如何通过云梦建站系统实现SEO快速优化?
网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?
高端企业智能建站程序:SEO优化与响应式模板定制开发
上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】
建站之星体验版:智能建站系统+响应式设计,多端适配快速建站
建站主机服务器选购指南:轻量应用与VPS配置解析
家庭服务器如何搭建个人网站?
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
已有域名如何快速搭建专属网站?
建站之星展会模板:智能建站与自助搭建高效解决方案
如何零成本快速生成个人自助网站?
如何基于云服务器快速搭建个人网站?
魔方云NAT建站如何实现端口转发?
制作公司内部网站有哪些,内网如何建网站?
C#怎么创建控制台应用 C# Console App项目创建方法
广东企业建站网站优化与SEO营销核心策略指南
郑州企业网站制作公司,郑州招聘网站有哪些?
音响网站制作视频教程,隆霸音响官方网站?
如何确保西部建站助手FTP传输的安全性?
PHP 500报错的快速解决方法
营销式网站制作方案,销售哪个网站招聘效果最好?
香港服务器网站卡顿?如何解决网络延迟与负载问题?
深圳企业网站制作设计,在深圳如何网上全流程注册公司?
宝盒自助建站智能生成技巧:SEO优化与关键词设置指南
*服务器网站为何频现安全漏洞?
杭州银行网站设计制作流程,杭州银行怎么开通认证方式?
香港服务器选型指南:免备案配置与高效建站方案解析
移民网站制作流程,怎么看加拿大移民官网?
在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。