### 什么是继承?
```
通过某种方式让一个对象可以访问到另外一个对象的方法和属性
```
### 为什么使用继承?
```
有些对象会有方法(动作、行为),而这些方法都是函数,如果把这些方法和函数都放在构造函数中声明就会导致内存的浪费
```
```
function Person(){
this.say=function(){
console.log("你好")
}
}
var p1=new Person();
var p2=new Person();
console.log(p1.say == p2.say); //false, 内存浪费
```
```
解决方法: 把say方法写到他们共同的父对象中
Person.prototype.say = function(){}
console.log(p1.say == p2.say); //true,指向了同一方法,避免了内存浪费
console.log(p1.say == Person.prototype.run); //true
结论:
只要在构造函数的prototype对象中添加某个属性方法,那么这样的属性和方法就可以被所有的构造函数的实例所共享
这里的构造函数的prototype对象称之为原型对象
```
```
p1, p2的原型对象是谁?
Person 创建了p1, p2, 所以Person.prototype是p1的原型对象
Person的原型对象是谁?
Function创建了Person, 所以Function.prototype是Person的原型
```
- 语言
- Javascript
- 简介
- 常量变量
- var
- let
- const
- 解构赋值
- 数据类型
- 简单数据类型
- Undefined
- Null
- Boolean
- Number
- String
- 引用数据类型
- Object
- Array
- Json
- 闭包
- 闭包中的变量
- 函数
- 函数参数
- arguments
- rest
- 传值方式
- 调用方式
- 函数调用
- 方法调用
- 构造函数
- 上下文
- 箭头函数
- 异步
- promise
- async/await
- 面向对象
- 简介
- 构造函数
- 创建对象
- 工厂模式
- 构造函数模式
- 原型模式
- 构造函数/原型组合模式
- 继承
- 什么是继承
- 怎么继承
- 原型链继承
- 拷贝继承
- 原型式继承
- 借用构造函数
- 对象扩展
- Object.assign
- 类
- 定义
- 类的继承
- 模块
- 定义模块
- 导入模块
- 简介
- 垃圾回收
- Typescript
- 简介
- 搭建环境
- 数据类型
- boolean
- number
- string
- array
- enum
- any
- void
- 类型推测
- 联合类型
- 类
- 定义
- 继承
- 封装
- static
- 函数
- 定义
- 参数
- 接口
- 属性类型接口
- 函数类型接口
- 数组类型接口
- 类类型接口
- 泛型
- 泛型函数
- 泛型类
- 模块
- 定义
- Node.js
- 简介
- IO优势
- Node与V8
- 内部机制
- 多线程
- 并发支持
- libuv
- 创建项目
- 安装Node
- 创建项目
- 全局对象
- console
- path
- process
- I/O
- 系统信息
- 命令行
- Buffer
- 模块
- 创建模块
- 导入模块
- 系统模块
- fs
- stat
- fstat
- 读
- 写
- http
- 服务端
- 客户端
- stream
- 4种基本类型
- event
- 事件监听
- 继承
- child_process
- spawn
- fork
- path
- url
- 三方模块
- socket.io
- 安装
- 例子
- server
- client
- redis
- 安装
- 编码
- 数据类型
- 键值对
- 散列表
- 列表
- 集合
- 发布订阅
- mongodb
- express
- mssql
- pm2
- qrcode
- ua-parse-js
- cpr
- js-cookie
- whatwg-fetch
- ora
- shelljs
- log4js
- Dart
- 框架
- Vue
- 简介
- 基础
- 声明式渲染
- Vue实例
- 模板语法
- 插值
- 文本
- 原始Html
- 特性
- js表达式
- 指令