ES5_对象 与 继承
1. 对象的定义
//定义对象
function User(){ //在构造方法中定义属性
this.name = '张三';
this.age = 12; //在构造方法中定义方法:
this.run = function(){
alert(this.name + '在跑步')
}
} //原型链中定义属性
User.prototype.sex = '男'; //原型链中定义方法
User.prototype.work = function(){
alert(this.name + '在工作')
} // 静态方法的声明
User.getInfo = function () {
alert('我是静态方法')
} //对象的使用: 实例化对象
var user = new User('张三', 3); //属性的调用
alert('姓名:'+ user.name + '; 性别:' + user.sex); // 弹出: 姓名:张三; 性别:男 //给对象属性重新赋值
user.name = '李四';
user.sex = '女'; //方法的调用
user.run(); // 弹出:李四在跑步
user.work(); // 弹出:李四在工作 //静态方法的调用
User.getInfo(); // 弹出: 我是静态方法
注意: 原型链中声明属性将会多个实例共享,而构造函数不会
对象的继承
1. 对象的继承 之 对象冒充继承
function User(){
this.name = '张三';
//在构造方法中定义方法:
this.run = function(){
alert(this.name + '在跑步')
}
}
//原型链中定义属性
User.prototype.sex = '男';
//原型链中定义方法
User.prototype.work = function(){
alert(this.name + '在工作')
}
//对象中的继承一: 对象冒充继承
function Student(){
//Student 继承 User对象,此方法叫: 对象冒充继承
User.call(this);
}
var student = new Student();
student.run(); // 弹出:张三在跑步
student.work(); //报错,原因是: 对象冒充继承的方法只继承对象的构造函数的属性和方法
注意: 对象冒充继承的方法 只能 继承对象的构造函数的属性和方法,不能 继承原型链中的函数和方法
2. 对象的继承 之 原型链继承
function User(){
this.name = '张三';
//在构造方法中定义方法:
this.run = function(){
alert(this.name + '在跑步')
}
}
//原型链中定义属性
User.prototype.sex = '男';
//原型链中定义方法
User.prototype.work = function(){
alert(this.name + '在工作')
}
//对象中的继承一: 原型链继承实现继承
function Student(){
}
Student.prototype = new User();
var student = new Student();
student.run(); // 弹出:张三在跑步
student.work(); // 弹出:张三在工作
注意:原型链继承的方法 可以 继承对象的构造函数的属性和方法,也可以 继承原型链中的函数和方法
function User(name){
this.name = name;
//在构造方法中定义方法:
this.run = function(){
alert(this.name + '在跑步')
}
}
//原型链中定义属性
User.prototype.sex = '男';
//原型链中定义方法
User.prototype.work = function(){
alert(this.name + '在工作')
}
//带参数对象的实例化方法:
var user1 = new User('张三');
user1.run(); // 弹出: 张三在跑步
user1.work(); // 弹出:张三在工作
//对象中的继承一: 原型链继承实现继承
function Student(name){
}
Student.prototype = new User();
var student = new Student('李四');
student.run(); // 弹出: undefined在跑步
student.work(); // 弹出:undefined在工作
注意:原型链继承有个缺点就是 在实例化子类时,无法 给父类传参,如上代码,子类调用父类的方法时, 弹出传参属性为 undefined
为了解决此缺点,则可以使用 冒充对象继承 + 原型链继承的组合模式
3. 冒充对象继承 + 原型链继承的组合模式
function User(name){
this.name = name;
//在构造方法中定义方法:
this.run = function(){
alert(this.name + '在跑步')
}
}
//原型链中定义属性
User.prototype.sex = '男';
//原型链中定义方法
User.prototype.work = function(){
alert(this.name + '在工作')
}
//对象中的继承一: 原型链继承实现继承
function Student(name){
//冒充对象继承时,可以给父类传参
User.call(this, name);
}
//原型链继承父类
//Student.prototype = new User();
//因冒充对象继承时,已经继承了父类的构造函数中的属性和方法,因此在原型链继承中也可只继承父类的原型链的属性和方法,即
Student.prototype = User.prototype;
var student = new Student('李四');
student.run(); // 弹出: 李四在跑步
student.work(); // 弹出:李四在工作
ES5_对象 与 继承的更多相关文章
- js最好的继承机制:用对象冒充继承构造函数的属性,用原型prototype继承对象的方法。
js最好的继承机制:用对象冒充继承构造函数的属性,用原型prototype继承对象的方法. function ClassA(sColor) { this.color = sColor; } Class ...
- 对象的继承关系在数据库中的实现方式和PowerDesigner设计
原文:对象的继承关系在数据库中的实现方式和PowerDesigner设计 在面向对象的编程中,使用对象的继承是一个非常普遍的做法,但是在关系数据库管理系统RDBMS中,使用的是外键表示实体(表)之间的 ...
- 类和对象:继承 - 零基础入门学习Python038
类和对象:继承 让编程改变世界 Change the world by program 上节课的课后作业不知道大家完成的怎样?我们试图模拟一个场景,里边有一只乌龟和十条鱼,乌龟通过吃鱼来补充体力,当乌 ...
- #JavaScript对象与继承
JavaScript对象与继承 JavaScript是我在C语言之后接触的第二门编程语言,大一暑假的时候在图书馆找了一本中国人写的JavaScript程序设计来看.那个时候在编程方面几乎还是小白,再加 ...
- Javascript学习6 - 类、对象、继承
原文:Javascript学习6 - 类.对象.继承 Javasciprt并不像C++一样支持真正的类,也不是用class关键字来定义类.Javascript定义类也是使用function关键字来完成 ...
- (79)Wangdao.com第十五天_JavaScript 对象的继承_prototype原型对象_封装_函数式编程
javascript 内置了许多 function 函数(){...} js 执行首先就会执行自己内置的函数定义 (function Function.function Object) 对象的继承 大 ...
- Javascript实现对象的继承
在Java和C#中,你可以简单的理解class是一个模子,对象就是被这个模子压出来的一批一批月饼.压个啥样,就得是个啥样,不能随便动,动一动就坏了.而在Javascript中,没有模子,月饼被换成了面 ...
- 关于js的对象原型继承(一)
javascript中,对象的继承是通过原型去继承. 可以这样理解:js中的对象,包含的除了属性和方法,还有一个最基本的原型__proto__对象.这个原型__proto__指向谁,这个对象就继承谁. ...
- js一种继承机制:用对象冒充继承构造函数的属性,用原型prototype继承对象的方法。
js一种继承机制:用对象冒充继承构造函数的属性,用原型prototype继承对象的方法. function ClassA(sColor) { this.color = sColor; } ClassA ...
随机推荐
- EOS require_auth函数
action的结构 要说清楚这个方法的含义和用法,咱们需要从action的结构说起.详见eoslib.hpp中的action类,这里把它的结构简化表示成下面这样: * struct action { ...
- Xamarin图表开发基础教程(3)OxyPlot框架
Xamarin图表开发基础教程(3)OxyPlot框架 Xamarin.Android中使用OxyPlot框架 在Xamarin.Android平台上实现图表显示需要完成以下的步骤: 1.添加OxyP ...
- win 10 关闭或打开 测试模式
一.关闭测试模式 方法: 以管理员身份运行 cmd 运行:bcdedit /set testsigning off 重启电脑 二.开启测试模式 以管理员身份运行 cmd 运行:bcdedit /set ...
- 使用adb命令控制anroid手机
adb工具即Android Debug Bridge(安卓调试桥) tools.它就是一个命令行窗口,用于通过电脑端与模拟器或者真实设备交互.在某些特殊的情况下进入不了系统或者需要自动化测试的时候, ...
- SQL查询无限层级结构的所有下级,所有上级(即所有的子孙曾孙等等)
表名:tb_menu 内容如下: 查询ID为3的所有无限层下级会员 WITH TAS( SELECT * FROM tb_menu WHERE id=3 UNION ALL SELECT a.* F ...
- jenkins回滚之groovy动态获取版本号
grovvy调试: 部署路径确定下来, 每个服务写死,传参 服务名 + 环境 给版本服务返回版本信息: groovy取分支: def gettags = ("git ls-remote -h ...
- Lambda的延迟执行
在兼顾面向对象特性的基础上,Java语言通过Lambda表达式与方法引用等,为开发者打开了函数式编程的大门. 下面我们做一个初探. Lambda的延迟执行 有些场景的代码执行后,结果不一定会被使用,从 ...
- Centos安装nodejs,并运行项目
不建议编译安装,对gcc要求比较高 安装nodejs yum install nodejs nodejs升级 npm i -g n --force n stable npm升级 npm install ...
- PAT(B) 1090 危险品装箱(Java)
题目链接:1090 危险品装箱 (25 point(s)) 题目描述 集装箱运输货物时,我们必须特别小心,不能把不相容的货物装在一只箱子里.比如氧化剂绝对不能跟易燃液体同箱,否则很容易造成爆炸. 本题 ...
- 深度学习-LSTM与GRU
http://www.sohu.com/a/259957763_610300此篇文章绕开了数学公式,对LSTM与GRU采用图文并茂的方式进行说明,尤其是里面的动图,让人一目了然.https://zyb ...