| |
|
开发:
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语言精粹学习之继承 -> 正文阅读 |
|
[JavaScript知识库]JavaScript语言精粹学习之继承 |
JavaScript也有面对对象,面的对象很重要的一点就是继承,语言精粹中的继承篇章写的复杂难懂,且有些东西和现在的es6相比太过于老了,读完后这里我自己整理了一下JavaScript的继承,也对语言精粹的继承进行解释简化 ? ? ? ? 这里我先上一张图直观地表示一下原型链 ? ? ?
? ? ? ? 怎么说呢,我可以先创建一个对象,然后去拜师 ????????
? ? ? ? 这里 b是先创建的,然后拜a为师,即从a处继承 ? ? ? ? 所有的对象都有一个__proto__属性,表示他的原型,如果创建的时候未指定原型,则默认原型为object,所有的对象,顺着原型一直往上推,他们的原型都是object,也就是说object在原型链的顶端,是所有对象的‘祖师爷’,这时有个问题,object的原型是什么?
? ? ? ? 当然语言精粹中并没有介绍这些,语言精粹介绍的是通过函数来创建对象,这样更好封装,但是通过上面这样讲原型链一下就理解了 ? ? ? ? 在讲解语言精粹之前,要先了解几个知识点
? ? ? ? 当我们new一个函数创建对象时,会执行以下操作
????????-?new?执行时 ????????????????1.??新建一个空对象 ????????????????2. 再把函数运行一遍,将 this??指向生成的对象 ????????????????2.?将对象返回
? ? ? ? 这样你再去看语言精粹中写的那几个函数其实就是为了揭示这一层关系,反过来理解的话就好理解了,其实语言精粹写的太复杂反而不太好懂,看到这里,你可以再去看开头的图,就会发现一目了然 ? ? ? ? 语言精粹后面的部分讲到的是封装思想,这里用到了上一章闭包的知识,当然语言精粹的作者用的处理方法非常秒 ????????
? ? ? ? ?我们创建了一个b对象,然而b没办法直接访问a的内容,因为他返回是一个c对象,用c的方法访问a的内容,而a对象中的变量因为闭包的原因不会被回收,且完全不可见 |
|
JavaScript知识库 最新文章 |
ES6的相关知识点 |
react 函数式组件 & react其他一些总结 |
Vue基础超详细 |
前端JS也可以连点成线(Vue中运用 AntVG6) |
Vue事件处理的基本使用 |
Vue后台项目的记录 (一) |
前后端分离vue跨域,devServer配置proxy代理 |
TypeScript |
初识vuex |
vue项目安装包指令收集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
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/28 12:12:00- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |