全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

JavaScript之面向对象_动力节点Java学院整理

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请求面向对象的封装  # 小明  # 是从  # 创建一个  # 基本概念  # 自己的  # 都是  # 如果你  # 很好  # 是一种  # 就在  # 一只  # 你可以  # 那是  # 多个  # 不太  # 还会  # 是指  # 而来  # 把它 


相关文章: 小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?  建站主机是否属于云主机类型?  如何在建站之星网店版论坛获取技术支持?  制作公司内部网站有哪些,内网如何建网站?  重庆市网站制作公司,重庆招聘网站哪个好?  昆明高端网站制作公司,昆明公租房申请网上登录入口?  北京制作网站的公司,北京铁路集团官方网站?  定制建站如何定义?其核心优势是什么?  XML的“混合内容”是什么 怎么用DTD或XSD定义  如何在阿里云虚拟服务器快速搭建网站?  宝塔建站教程:一键部署配置流程与SEO优化实战指南  宝塔Windows建站如何避免显示默认IIS页面?  如何撰写建站申请书?关键要点有哪些?  保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?  相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?  网站制作网站,深圳做网站哪家比较好?  c++怎么用jemalloc c++替换默认内存分配器【性能】  如何在Golang中引入测试模块_Golang测试包导入与使用实践  专业网站制作服务公司,有哪些网站可以免费发布招聘信息?  如何在云虚拟主机上快速搭建个人网站?  如何基于云服务器快速搭建个人网站?  英语简历制作免费网站推荐,如何将简历翻译成英文?  企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?  如何用低价快速搭建高质量网站?  如何处理“XML格式不正确”错误 常见XML well-formed问题解决方法  广州网站建站公司选择指南:建站流程与SEO优化关键词解析  大连网站制作公司哪家好一点,大连买房网站哪个好?  子杰智能建站系统|零代码开发与AI生成SEO优化指南  如何用免费手机建站系统零基础打造专业网站?  如何用西部建站助手快速创建专业网站?  javascript中的try catch异常捕获机制用法分析  网站建设制作、微信公众号,公明人民医院怎么在网上预约?  网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?  义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?  如何在阿里云完成域名注册与建站?  高端建站三要素:定制模板、企业官网与响应式设计优化  如何获取上海专业网站定制建站电话?  建站上市公司网站建设方案与SEO优化服务定制指南  宿州网站制作公司兴策,安徽省低保查询网站?  Python如何创建带属性的XML节点  建站主机如何选?性能与价格怎样平衡?  小型网站制作HTML,*游戏网站怎么搭建?  测试制作网站有哪些,测试性取向的权威测试或者网站?  如何优化Golang Web性能_Golang HTTP服务器性能提升方法  如何快速搭建二级域名独立网站?  已有域名如何免费搭建网站?  ,有什么在线背英语单词效率比较高的网站?  网站制作公司广州有几家,广州尚艺美发学校网站是多少?  网站制作的步骤包括,正确网址格式怎么写?  网站制作员失业,怎样查看自己网站的注册者? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。