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_对象 与 继承的更多相关文章

  1. js最好的继承机制:用对象冒充继承构造函数的属性,用原型prototype继承对象的方法。

    js最好的继承机制:用对象冒充继承构造函数的属性,用原型prototype继承对象的方法. function ClassA(sColor) { this.color = sColor; } Class ...

  2. 对象的继承关系在数据库中的实现方式和PowerDesigner设计

    原文:对象的继承关系在数据库中的实现方式和PowerDesigner设计 在面向对象的编程中,使用对象的继承是一个非常普遍的做法,但是在关系数据库管理系统RDBMS中,使用的是外键表示实体(表)之间的 ...

  3. 类和对象:继承 - 零基础入门学习Python038

    类和对象:继承 让编程改变世界 Change the world by program 上节课的课后作业不知道大家完成的怎样?我们试图模拟一个场景,里边有一只乌龟和十条鱼,乌龟通过吃鱼来补充体力,当乌 ...

  4. #JavaScript对象与继承

    JavaScript对象与继承 JavaScript是我在C语言之后接触的第二门编程语言,大一暑假的时候在图书馆找了一本中国人写的JavaScript程序设计来看.那个时候在编程方面几乎还是小白,再加 ...

  5. Javascript学习6 - 类、对象、继承

    原文:Javascript学习6 - 类.对象.继承 Javasciprt并不像C++一样支持真正的类,也不是用class关键字来定义类.Javascript定义类也是使用function关键字来完成 ...

  6. (79)Wangdao.com第十五天_JavaScript 对象的继承_prototype原型对象_封装_函数式编程

    javascript 内置了许多 function 函数(){...} js 执行首先就会执行自己内置的函数定义 (function Function.function Object) 对象的继承 大 ...

  7. Javascript实现对象的继承

    在Java和C#中,你可以简单的理解class是一个模子,对象就是被这个模子压出来的一批一批月饼.压个啥样,就得是个啥样,不能随便动,动一动就坏了.而在Javascript中,没有模子,月饼被换成了面 ...

  8. 关于js的对象原型继承(一)

    javascript中,对象的继承是通过原型去继承. 可以这样理解:js中的对象,包含的除了属性和方法,还有一个最基本的原型__proto__对象.这个原型__proto__指向谁,这个对象就继承谁. ...

  9. js一种继承机制:用对象冒充继承构造函数的属性,用原型prototype继承对象的方法。

    js一种继承机制:用对象冒充继承构造函数的属性,用原型prototype继承对象的方法. function ClassA(sColor) { this.color = sColor; } ClassA ...

随机推荐

  1. Xamarin图表开发基础教程(9)OxyPlot框架

    Xamarin图表开发基础教程(9)OxyPlot框架 OxyPlot组件构成 OxyPlot组件主要由两个类构成,分别为PlotView和PlotModel.这两个类我们在上文中也使用到了.本节将讲 ...

  2. 判断命令test

    判断命令test一般用于脚本当中,可以简写为中括号[ ].其会对跟随的条件进行判断,一般可以分为数值判断.字符串判断和文件判断.语法格式为test [判断条件]或[ 判断条件 ],注意中括号[ ]与判 ...

  3. idea tomcat部署项目路径

    在idea中配置的tomcat,在运行时idea不会把项目放到该路径下,而是复制一份足够的配置文件,到 ${user.home}/.IntelliJIdea/system/tomcat 目录下: C: ...

  4. 基于EasyNVR摄像机无插件直播方案二次开发实现自己的摄像机IPC-NVR无插件化直播解决方案

    背景介绍 在之前的博客中<基于EasyNVR实现RTSP/Onvif监控摄像头Web无插件化直播监控>,对EasyNVR所实现的功能我们已经有较多描述,这些也在方案地址:http://ww ...

  5. 大名鼎鼎的UniDAC手工安装

    第一次开博,该写点什么.由于懒,很多事情,都不想动.不过,懒不能解决遗忘的毛病.还是动手,记录一下吧. 好了,言归主题. UniDAC 的手工安装. 现在Delphi,已经发展到了XE6,支持多种移动 ...

  6. [转]Ubuntu18.04下安装搜狗输入法

    鏈接地址:https://blog.csdn.net/lupengCSDN/article/details/80279177

  7. [LeetCode] 304. Range Sum Query 2D - Immutable 二维区域和检索 - 不可变

    Given a 2D matrix matrix, find the sum of the elements inside the rectangle defined by its upper lef ...

  8. Java高级面试题整理(附答案)

    这是我收集的10道高级Java面试问题列表.这些问题主要来自 Java 核心部分 ,不涉及 Java EE 相关问题.你可能知道这些棘手的 Java 问题的答案,或者觉得这些不足以挑战你的 Java ...

  9. 西门子PLC1200内使用SCL实现简化版PID算法

    西门子自带的PID效果很好,但是会比较吃性能,使用次数有限,很多地方需要PID但不需要这么精准的PID,所以网上找个简单的算法自己调用. 新建数据类型 前三个就是PID三个参数 新建FC块: #PID ...

  10. 学习数据结构Day3

    栈和队列 栈是一种线性结构,相比数组 他对应的操作是数组的子集 只能从一端进入,也只能从一端取出 这一端成为栈顶 栈是一种先进后出的数据结构,Last In First Out(LIFO) 程序调用的 ...