百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 优雅编程 > 正文

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

sinye56 2024-10-27 14:12 9 浏览 0 评论

  好程序员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 上

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

继承

一个小例子

继承的作用

  • 这样,每一个实例使用的方法就都是来自构造函数的 prototype 上
  • 就避免了函数重复出现占用内存得到情况
  • 那么,如果两个构造函数的 prototype 中有一样的方法呢,是不是也是一种浪费
  • 所以我们把构造函数? prototype 中的公共的方法再次尽心提取
  • 我们准备一个更公共的构造函数,让构造函数的 __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()

}}

  • 这样就继承成功了

相关推荐

程序员:JDK的安装与配置(完整版)_jdk的安装方法

对于Java程序员来说,jdk是必不陌生的一个词。但怎么安装配置jdk,对新手来说确实头疼的一件事情。我这里以jdk10为例,详细的说明讲解了jdk的安装和配置,如果有不明白的小伙伴可以评论区留言哦下...

Linux中安装jdk并配置环境变量_linux jdk安装教程及环境变量配置

一、通过连接工具登录到Linux(我这里使用的Centos7.6版本)服务器连接工具有很多我就不一一介绍了今天使用比较常用的XShell工具登录成功如下:二、上传jdk安装包到Linux服务器jdk...

麒麟系统安装JAVA JDK教程_麒麟系统配置jdk

检查检查系统是否自带java在麒麟系统桌面空白处,右键“在终端打开”,打开shell对话框输入:java–version查看是否自带java及版本如图所示,系统自带OpenJDK,要先卸载自带JDK...

学习笔记-Linux JDK - 安装&配置

前提条件#检查是否存在JDKrpm-qa|grepjava#删除现存JDKyum-yremovejava*安装OracleJDK不分系统#进入安装文件目...

Linux新手入门系列:Linux下jdk安装配置

本系列文章是把作者刚接触和学习Linux时候的实操记录分享出来,内容主要包括Linux入门的一些理论概念知识、Web程序、mysql数据库的简单安装部署,希望能够帮到一些初学者,少走一些弯路。注意:L...

测试员必备:Linux下安装JDK 1.8你必须知道的那些事

1.简介在Oracle收购Sun后,Java的一系列产品就被整合到Oracle官网中,打开官网乍眼一看也不知道去哪里下载,还得一个一个的摸索尝试,而且网上大多数都是一些Oracle收购Sun前,或者就...

Linux 下安装JDK17_linux 安装jdk1.8 yum

一、安装环境操作系统:JDK版本:17二、安装步骤第一步:下载安装包下载Linux环境下的jdk1.8,请去官网(https://www.oracle.com/java/technologies/do...

在Ubuntu系统中安装JDK 17并配置环境变量教程

在Ubuntu系统上安装JDK17并配置环境变量是Java开发环境搭建的重要步骤。JDK17是Oracle提供的长期支持版本,广泛用于开发Java应用程序。以下是详细的步骤,帮助你在Ubuntu系...

如何在 Linux 上安装 Java_linux安装java的步骤

在桌面上拥抱Java应用程序,然后在所有桌面上运行它们。--SethKenlon(作者)无论你运行的是哪种操作系统,通常都有几种安装应用程序的方法。有时你可能会在应用程序商店中找到一个应用程序...

Windows和Linux环境下的JDK安装教程

JavaDevelopmentKit(简称JDK),是Java开发的核心工具包,提供了Java应用程序的编译、运行和开发所需的各类工具和类库。它包括了JRE(JavaRuntimeEnviro...

linux安装jdk_linux安装jdk软连接

JDK是啥就不用多介绍了哈,外行的人也不会进来看我的博文。依然记得读大学那会,第一次实验课就是在机房安装jdk,编写HelloWorld程序。时光飞逝啊,一下过了十多年了,挣了不少钱,买了跑车,娶了富...

linux安装jdk,全局配置,不同用户不同jdk

jdk1.8安装包链接:https://pan.baidu.com/s/14qBrh6ZpLK04QS8ogCepwg提取码:09zs上传文件解压tar-zxvfjdk-8u152-linux-...

运维大神教你在linux下安装jdk8_linux安装jdk1.7

1.到官网下载适合自己机器的版本。楼主下载的是jdk-8u66-linux-i586.tar.gzhttp://www.oracle.com/technetwork/java/javase/downl...

window和linux安装JDK1.8_linux 安装jdk1.8.tar

Windows安装JDK1.8的步骤:步骤1:下载JDK打开浏览器,找到JDK下载页面https://d.injdk.cn/download/oraclejdk/8在页面中找到并点击“下载...

最全的linux下安装JavaJDK的教程(图文详解)不会安装你来打我?

默认已经有了linux服务器,且有root账号首先检查一下是否已经安装过java的jdk任意位置输入命令:whichjava像我这个已经安装过了,就会提示在哪个位置,你的肯定是找不到。一般我们在...

取消回复欢迎 发表评论: