IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> JavaScript高级复习02-面向对象三大特征原型链 -> 正文阅读

[JavaScript知识库]JavaScript高级复习02-面向对象三大特征原型链

面向对象三大特征

  1. 封装:把代码放入对象的方法中

  1. 继承:子对象拥父对象的所有属性和方法(js的重点)

  1. 多态:一个对象在不同情况下的多种状态

继承

  1. 混入式继承: 遍历父对象成员, 添加给子元素

特点: 单个对象继承

  1. 替换原型继承: 父对象作为子对象构造函数的原型

特点: 多个对象继承,但是会覆盖原来的默认原型

  1. 混合式继承: 混入式+替换原型 遍历父元素成员, 添加给子对象构造函数原型

特点: 多个对象继承,不会覆盖原来的默认原型

混入式继承

 ?<script> ? ?
    // 父对象
 ? ?let father = {
 ? ? ?house: {
 ? ? ? ?address: '光谷天地',
 ? ? ? ?price: 10000000
 ? ?  },
 ? ? ?car: {
 ? ? ? ?brand: '宝马',
 ? ? ? ?price: 1000000
 ? ?  }
 ?  }
?
 ? ?// 子对象
 ? ?let son = {
 ? ? ?name: '张三',
 ? ? ?age: 18
 ?  }
?
 ? ?// 混入式继承: 遍历父对象成员,添加给子元素
 ? ?// 特点: 单个对象继承
 ? ?for (let key in father) {
 ? ? ?son[key] = father[key]
 ?  }
 ? ?console.log(son)
 ?</script>

替换原型继承

 ?<script>
 ? ?// 父对象
 ? ?let father = {
 ? ? ?house: {
 ? ? ? ?address: '光谷天地',
 ? ? ? ?price: 10000000
 ? ?  },
 ? ? ?car: {
 ? ? ? ?brand: '宝马',
 ? ? ? ?price: 1000000
 ? ?  }
 ?  }
?
 ? ?// 子对象构造函数
 ? ?function son(name, age) {
 ? ? ?this.name = name
 ? ? ?this.age = age
 ?  }
?
 ? ?// 子对象的默认原型
 ? ?son.prototype.hobby = function () {
 ? ? ?console.log('打麻将')
 ?  }
?
 ? ?// 替换原型继承: 父对象作为子对象构造函数的原型
 ? ?// 特点: 用于多对象继承,但是会覆盖原来的原型
 ? ?son.prototype = father
 ? ?
 ? ?let son1 = new son('张三', 20)
 ? ?let son2 = new son('李四', 30)
 ? ?console.log(son1, son2)

混合式继承

 ?<script>
 ? ?// 父对象
 ? ?let father = {
 ? ? ?house: {
 ? ? ? ?address: '光谷天地',
 ? ? ? ?price: 10000000
 ? ?  },
 ? ? ?car: {
 ? ? ? ?brand: '宝马',
 ? ? ? ?price: 1000000
 ? ?  }
 ?  }
?
 ? ?// 子对象构造函数
 ? ?function son(name, age) {
 ? ? ?this.name = name
 ? ? ?this.age = age
 ?  }
?
 ? ?// 子对象的默认原型
 ? ?son.prototype.hobby = function () {
 ? ? ?console.log('打麻将')
 ?  }
?
 ? ?// 混入式继承: 混入式+替换原型  遍历父元素成员,添加给子对象构造函数原型
 ? ?// 特点: 多对象继承,不会覆盖原来的默认原型
 ? ?for (let key in father) {
 ? ? ?son.prototype[key] = father[key]
 ?  }
 ? ?
 ? ?let son1 = new son('张三', 20)
 ? ?let son2 = new son('李四', 30)
 ? ?console.log(son1, son2)
 ?</script>

原型链

  1. 原型链:每一个对象都有原型,原型本身又是对象,所以原型又有原型,以此类推形成一个链式结构,称为原型链

  1. 对象访问原型链中成员的规则:就近原则

    当访问一个对象的成员变量时,会首先访问它自身的成员变量,如果有则访问。没有则在原型中寻找,能找到就访问,不能找到则继续往原型的原型中寻找,以此类推,如果找到原型链的顶端还是找不到,则程序报错: xxx is not a function

  1. 原型链的作用: 继承

    js用"原型链"实现面向对象继承

    几乎所有的框架底层都是用原型链实现继承

面对对象补充:

静态成员与实例成员

  1. 静态成员 : 属于函数对象的成员

  2. 实例成员: 属于实例化对象的成员

<script>
        //构造函数
         function Person(name,age){
            this.name = name
            this.age = age
        }
        Person.aaa = '啊啊啊'
        console.log(Person.aaa)//静态成员      

        //实例化对象
        let p1 = new Person('张三',20)
        console.log(p1.name)//实例成员
        console.log(p1.age)//实例成员
        
    </script>

instanceof运算符

  1. instanceof关键字(运算符): 检测构造函数的原型prototype在不在这个对象的原型链上

  2. 作用:限制函数的参数数据类型

  3. 语法:实例对象 instanceof 构造函数

    <script>
        //数组实例对象
        // arr->Array.prototype->Object.prototype->null
        let arr = [10,20,30]

        console.log( arr instanceof Array )//true
        console.log( arr instanceof Object )//true
        console.log( arr instanceof String )//false
        
        //报错: 参数不是节点   
        //instanceof关键字一般用在函数中,用于限制参数的数据类型
        //例如 appendChild()参数只能是node节点,如果你传了其他类型就会报错。底层就会用到instanceof来检测参数数据类型
        let h1 = document.createElement('h1')
        h1.innerText = '我是h1标签'
        document.body.appendChild(h1)   
    </script>

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-12-26 22:03:48  更:2021-12-26 22:04:56 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 0:00:25-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码