我的编程空间,编程开发者的网络收藏夹
学习永远不晚

好程序员web前端培训分享JavaScript学习笔记闭包与继承

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

好程序员web前端培训分享JavaScript学习笔记闭包与继承

  好程序员web前端培训分享JavaScript学习笔记闭包与继承,闭包:闭包是我们函数的一种高级使用方式,在聊闭包之前我们要先回顾一下 函数

函数的两个阶段

  • 我们一直说函数有两个阶段
  1. 定义阶段
  2. 调用阶段
  3. 开辟一个 存储空间
  4. 把函数体内的代码一模一样的放在这个空间内(不解析变量)
  5. 把 存储空间 的地址给函数名
  6. 按照函数名的地址找到函数的 存储空间
  7. 形参赋值
  8. 预解析
  9. 将函数 存储空间 中的代码拿出来执行(才解析变量)
  10. 按照函数名的地址找到函数的 存储空间
  11. 形参赋值
  12. 预解析
  13. 在内存中开辟一个 执行空间
  14. 将函数 存储空间 中的代码拿出来在刚刚开辟的 执行空间 中执行
  15. 执行完毕后,内存中开辟的 执行空间 销毁

函数定义阶段

函数调用阶段

重新定义函数调用阶段

function fn() {

    console.log('我是 fn 函数')}fn() 

  • 函数执行的时候会开辟一个 执行空间 (我们暂且叫他 xxff00)
  • console.log('我是 fn 函数') 这个代码就是在 xxff00 这个空间中执行
  • 代码执行完毕以后,这个 xxff00 空间就销毁了
  • 每一个函数会有一个 存储空间
  • 但是每一次调用都会生成一个完全不一样的 执行空间
  • 并且 执行空间 会在函数执行完毕后就销毁了,但是 存储空间 不会
  • 那么这个函数空间执行完毕就销毁了,还有什么意义呢?
  • 我们可以有一些办法让这个空间 不销毁
  • 闭包,就是要利用这个 不销毁的执行空间
  • 函数的 执行空间 会在函数执行完毕之后销毁
  • 但是,一旦函数内部返回了一个 引用数据类型,并且 在函数外部有变量接受 的情况下
  • 那么这个函数 执行空间 就不会销毁了

函数执行空间

函数执行空间不销毁

function fn() {

   const obj = {

       name: 'Jack',

       age: 18,

       gender: '男'

   }

   return obj}const o = fn()

  • 函数执行的时候,会生成一个函数 执行空间 (我们暂且叫他 xxff00)
  • 代码在 xxff00 空间中执行
  • 在 xxff00 这个空间中声名了一个 对象空间(xxff11)
  • 在 xxff00 这个执行空间把 xxff11 这个对象地址返回了
  • 函数外部 0 接受的是一个对象的地址没错
  • 但是是一个在 xxff00 函数执行空间中的 xxff11 对象地址
  • 因为 o 变量一直在和这个对象地址关联着,所以 xxff00 这个空间一直不会销毁
  • 等到什么时候,执行一句代码 o = null
  • 此时, o 变量比在关联在 xxff00 函数执行空间中的 xxff11 对象地址
  • 那么,这个时候函数执行空间 xxff00 就销毁了
  • 闭包就是利用了这个函数执行空间不销毁的逻辑
  • 有几个条件组成闭包
  • 闭包的第一个条件就是利用了不销毁空间的逻辑
  • 只不过不是返回一个 对象数据类型
  • 而是返回一个 函数数据类型

闭包

不销毁的空间

function fn() {

    return function () {}}const f = fn()

  • f 变量接受的就是一个 fn的执行空间 中的 函数
  • 涉及到两个函数
  • 内部函数要查看或者使用着外部函数的变量

内部函数引用外部函数中的变量

function fn() {

   const num = 100

   // 这个函数给一个名字,方便写笔记   return function a() {

       console.log(num)

   }}const f = fn()

  • fn() 的时候会生成一个 xxff00 的执行空间
  • 再 xxff00 这个执行空间内部,定义了一个 a 函数的 存储空间xxff11
  • 全局 f 变量接受的就是 xxff00 里面的 xxff11
  • 所以 xxff00 就是不会销毁的空间
  • 因为 xxff00 不会销毁,所以,定义再里面的变量 num 也不会销毁
  • 将来 f() 的时候,就能访问到 num 变量
  • 为什么要叫做特点,就是因为他的每一个点都是优点同时也是缺点

闭包的特点

  1. 作用域空间不销毁
  • 优点: 因为不销毁,变量页不会销毁,增加了变量的生命周期
  • 缺点: 因为不销毁,会一直占用内存,多了以后就会导致内存溢出

 

  1. 可以利用闭包访问再一个函数外部访问函数内部的变量
  • 优点: 可以再函数外部访问内部数据
  • 缺点: 必须要时刻保持引用,导致函数执行栈不被销毁

 

  1. 保护私有变量
  • 优点: 可以把一些变量放在函数里面,不会污染全局
  • 缺点: 要利用闭包函数才能访问,不是很方便
  • 有一个 A 函数,再 A 函数内部返回一个 B 函数
  • 再 A 函数外部有变量引用这个 B 函数
  • B 函数内部访问着 A 函数内部的私有变量
  • 以上三个条件缺一不可
  • 继承是和构造函数相关的一个应用
  • 是指,让一个构造函数去继承另一个构造函数的属性和方法
  • 所以继承一定出现在 两个构造函数之间
  • 我们之前说,构造函数(类)是对一类行为的描述
  • 那么我们类这个概念其实也很抽象
  • 比如:
  • 我们说 国光 / 富士 都是 苹果的品种,那么我们就可以写一个 苹果类 来实例化很多品种出来
  • 而 苹果 / 梨 这些东西都是水果的一种,那么我们就可以写一个 水果类
  • 说过的统一特点就是 甜 / 水分大 ,而不同的水果有不同的特征
  • 那么我们就可以让 苹果类 来继承 水果类 的内容,然后再用 水果类 去实例化对象
  • 那么实例化出来的就不光有 苹果类 的属性和方法,还有 水果类 的属性和方法
  • 其实说到底,到底什么是继承
  • 我们之前说,在我们书写构造函数的时候,为了解决一个函数重复出现的问题
  • 我们把构造函数的 方法 写在了 prototype 上

闭包概念(熟读并背诵全文)

继承

一个小例子

继承的作用

好程序员web前端培训分享JavaScript学习笔记闭包与继承

  • 这样,每一个实例使用的方法就都是来自构造函数的 prototype 上
  • 就避免了函数重复出现占用内存得到情况
  • 那么,如果两个构造函数的 prototype 中有一样的方法呢,是不是也是一种浪费
  • 所以我们把构造函数䣌 prototype 中的公共的方法再次尽心提取

    好程序员web前端培训分享JavaScript学习笔记闭包与继承

  • 我们准备一个更公共的构造函数,让构造函数的 __proto__ 指向这个公共的构造函数的 prototype
  • 我们有一些常见的继承方式来实现和达到继承的效果
  • 我们先准备一个父类(也就是要让别的构造函数使用我这个构造函数的属性和方法)

常见的继承方式

function Person() {

    this.name = 'Jack'}Person.prototype.sayHi = function () {

    cosnole.log('hello')}

  • 这个 Person 构造函数为父类
  • 让其他的构造函数来继承他
  • 当别的构造函数能够使用他的属性和方法的时候,就达到了继承的效果
  • 原型继承,就是在本身的原型链上加一层结构

原型继承

function Student() {}Student.prototype = new Person()

借用构造函数继承

  • 把父类构造函数体借用过来使用一下而已

function Student() {

    Person.call(this)}

组合继承

  • 就是把 原型继承 和 借用构造函数继承 两个方式组合在一起

function Student() {

    Person.call(this)}Student.prototype = new Person

ES6 的继承

  • es6 的继承很容易,而且是固定语法
    // 下面表示创造一个 Student 类,继承自 Person 类

class Student extends Person {

    constructor () {

        // 必须在 constructor 里面执行一下 super() 完成继承         super()

    }}

  • 这样就继承成功了

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

好程序员web前端培训分享JavaScript学习笔记闭包与继承

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

好程序员web前端培训分享JavaScript学习笔记闭包与继承

  好程序员web前端培训分享JavaScript学习笔记闭包与继承,闭包:闭包是我们函数的一种高级使用方式,在聊闭包之前我们要先回顾一下 函数函数的两个阶段我们一直说函数有两个阶段定义阶段调用阶段开辟一个 存储空间把函数体内的代码一模一样
2023-06-03

好程序员web前端培训分享JavaScript学习笔记SASS

  好程序员web前端培训分享JavaScript学习笔记SASS,世界上最成熟、最稳定、最强大的专业级CSS扩展语言!· sass 是一个 css 的预编译工具· 也就是能够 更优雅 的书写 css· sass 写出来的东西 浏览器不认识
2023-06-03

好程序员web前端培训分享JavaScript学习笔记之ES5

  好程序员web前端培训分享JavaScript学习笔记之ES5,我们所说的 ES5 和 ES6 其实就是在 js 语法的发展过程中的一个版本而已  比如我们使用的微信  最早的版本是没有支付功能的  随着时间的流逝,后来出现了一个版本,
2023-06-03

好程序员web前端培训分享学习JavaScript

好程序员web前端教程分享学习JavaScript,我试着总结自己学习JavaScript的方法 JavaScript给人那种感觉的原因多半是因为它如下的特点: 1、本身知识很抽象、晦涩难懂,如:闭包、内置对象、DOM。2、本身内容很多,如
2023-06-03

好程序员web前端培训分享JavaScript学习笔记ajax及ajax封装

  好程序员web前端培训分享JavaScript学习笔记ajax及ajax封装,ajax 全名 async javascript and XML  是前后台交互的能力  也就是我们客户端给服务端发送消息的工具,以及接受响应的工具  是一个
2023-06-03

好程序员web前端培训分享JavaScript学习笔数组的排序

  好程序员web前端培训分享JavaScript学习笔数组的排序,排序,就是把一个乱序的数组,通过我们的处理,让他变成一个有序的数组,今天我们讲解两种方式来排序一个数组 冒泡排序 和 选择排序冒泡排序· 先遍历数组,让挨着的两个进行比较,
2023-06-03

​好程序员web前端培训分享node学习笔记系列之四十一

好程序员web前端培训分享node学习笔记系列之四十一一、手动封装body-parser中间件 cookie-parser中间件1、封装axios请求方式body-parserconst qs = require("querystring"
2023-06-03

好程序员web前端培训分享怎样学好css?

  好程序员web前端培训分享怎样学好css?我推荐题主的学习方法就是:善用调试工具。  使用谷歌浏览器进行调试,在属性不理解时可以直接在浏览器里进行数值调节  css在书写时由于选择器权重问题经常出现样式覆盖的问题  如果你的选择器书写正
2023-06-03

好程序员web前端培训分享HTMLCSS学习之CSS基础

  好程序员web前端培训分享HTMLCSS学习之CSS基础,CSS(cascading style sheet) 汉译为层叠样式表,是用于控制网页样式WEB标准中的表现标准语言,在网页中主要对网页信息的显示进行控制。目前推荐遵循的是W3C
2023-06-03

好程序员web前端教程分享JavaScript学习笔记之Event事件二

  好程序员web前端教程分享JavaScript学习笔记之Event事件二,今天来聊一聊事件的执行机制。  什么是事件的执行机制呢?  思考一个问题?  当一个大盒子嵌套一个小盒子的时候,并且两个盒子都有点击事件你点击里面的小盒子,外面的
2023-06-03

好程序员web前端培训分享做H5页面需要学什么

  好程序员web前端培训分享做H5页面需要学什么,很多人问过我这个问题,而问这个问题的人基本上都是刚听说过h6,处在懵懂的阶段,他们往往会被一些网上炫酷页面所吸引,开始的目的也很简单,能通过自己的努力做出这些页面,而这些页面效果一般只要通
2023-06-03

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录