3、函数定义,函数调用,this指向总结,闭包

一、函数的定义方式

1、函数声明

function demo1() {var num = 12var result = Math.pow(num,2)//指数函数return result
}

2、函数表达式

var demo2 = function (x,y) {
//内置对象arguments前面的两个参数  是 x,yvar sum = arguments[0] + arguments[1]console.log(sum)
}

3、构造函数

var demo3 = new Function("x","y","return x+y")

二、函数的调用方式

1、函数名()

console.log(demo1())//144
demo(10,20)//30
var re = demo3(1.2,1.3)
console.log(re)//2.5

2、call() / apply()

console.log(demo1.call())//144
console.log(demo1.apply())//144
demo2.call(window, 1, 2)//3
demo2.apply(null, [4, 5])//9

3、自调用

函数表达式自调用

var fn1 = (function () {console.log('this is function')//this is function
})()

匿名函数

(function () {console.log('我是匿名函数')//我是匿名函数
})()

4、对象中的函数调用

var obj = {school: '学校',study: function () {console.log('我是对象的函数')//我是对象的函数},
}
//要用obj去调用  因为所属对象是objobj.study()

5、数组中函数的调用

var arr = [10,'0',undefined,null,false,[2, 3],function () {console.log('我是函数也是数组的元素')//我是函数也是数组的元素console.log(this)//[10, '0', undefined, null, false, Array(2), ƒ, {…}]},{},]arr[6]()

6、函数当做参数调用

function demo4(x) {x()
}
demo4(function () {alert('我是函数也是demo4的参数')//弹窗 我是函数也是demo4的参数
})

7、函数当做返回值的调用

function demo5() {return function () {console.log('我是函数也是demo5的返回值')}
}
demo5()()

如果函数A的返回值是匿名函数B,想要调用匿名函数B 直接再函数A 后面加两个小括号

三、函数中this指向问题(总结)

  • 1、在普通函数中this指向window
function fn1() {console.log(this)}
fn1()//window
  • 2、在定时器函数中this指向window
var timer = setInterval(function(){console.log(this);//window
},2000)
  • 3、在事件函数中this指向事件源
var btn = document.getElementById("btn")
btn.onclick = function() {console.log(this)//btn
}
  • 4、在对象函数中this指向当前对象
var name = "this window"
var object = {name: 'this object',getName: function () {//this object在对象函数中this指向当前对象(this指向)console.log(this.name);console.log(name);//this window 当前没有  往上查找(作用域链查找)}
}
object.getName()
  • 5、在构造函数中this指向实例化对象
function Person(age,name) {this.age = agethis.name = nameconsoel.log(this)//this指向Person的实例对象p1
}
var p1 = new Person(18,;'张哈哈')
  • 6、在原型函数中
    • 如果原型调用,this指向原型
    • 如果实例化对象调用,this指向实例化对象
  • 7、在数组函数中this指向当前数组

四、闭包

1、作用域

有且只有函数 才可以产生作用域

全局作用域(永恒作用域)

  • 全局变量
  • 在任何作用域内都有效
  • 生命周期:浏览器打开时创建,关闭时销毁

局部作用域

  • 局部变量
  • 只在当前作用域内有效
  • 生命周期:函数调用时创建,调用完成后销毁

2、闭包的定义?

  • 定义在函数内部的函数

3、闭包的作用?

获取父函数内部的变量

console.log(count)//获取不到  因为count是局部的
var num = 15
function parent() {console.log(num)//15 num是全局的var count = 12.4// 闭包函数的本质// 局部作用域--parent,相对于child作用域是永恒的,本身是作用域是短暂的 function child() {//  局部作用域--childconsole.log(count)}child()
}
parent()

锁住父函数内部的变量

// 随机数案例
var getRandom = function (min, max) {var num = Math.floor(Math.random() * (max - min) + min)return function(){console.log(num);}
}
var result = getRandom(10, 20)
// 两次结果一样 因为父元素执行一次 
result()
result()
var btn = document.getElementById("btn")
btn.onclick = (function () {var count = 0return function () {count++console.log(this)//由于事件是异步的,所以自调用的是父函数,此时父函数是匿名函数,所以单击事件调用闭包函数this.innerText = "点赞(" + count + ")"}
})()

image-20240226195738360

4、闭包函数的本质?

  • 让父函数相对于闭包函数是永恒作用域

5、闭包作用域之获取复函数内部变量

  • this 指向 作用域链的查找规则 预解析 闭包
var name = "this window"
var object = {//不会产生作用域name: 'this object',getName: function () {//局部作用域console.log(this.name);//在对象函数中this指向当前对象console.log(name);//在当前作用域查找  undefinedvar name = "this getName"//var name提升return function () {console.log(this.name);//普通函数 this指向windowconsole.log(name);//this getName  当前作用域没有 往上一级查找}}
} 
object.getName()()
var name = "this window"
var object = {//不会产生作用域name: 'this object',getName: function () {//局部作用域console.log(this.name);//this object 在对象函数中this指向当前对象console.log(name);//在当前作用域查找  undefinedvar name = "this getName"//var name提升return function () {function name(){console.log('我是函数声明');}var name = function () {console.log(this.name);//普通函数指向window}//this object  因为this 指向bind(this)中的this bind的指向objectconsole.log(this.name);console.log(name);//this getName函数  当前作用域有name 函数表达式覆盖函数声明name()}.bind(this)return name}
}
object.getName()()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/704618.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【物联网应用案例】唐山世园会照明管理项目

世园会作为国际盛会,不仅仅是一次花卉和园艺的展示,更是城市形象和文化的集中展现。夜间照明系统作为其中的重要组成部分,其重要性不言而喻。它不仅关乎着每一位到访游客的视觉体验,更是城市名片的重要展示。 为了给游客带来一次…

精品基于SpringBoot+Vue的常规应急物资管理系统

《[含文档PPT源码等]精品基于SpringBootVue的常规应急物资管理系统[包运行成功]》该项目含有源码、文档、PPT、配套开发软件、软件安装教程、项目发布教程、包运行成功! 软件开发环境及开发工具: Java——涉及技术: 前端使用技术&#xff…

十五届蓝桥杯第三期模拟赛题单(C++、java、Python)

备战2024年蓝桥杯 省赛第三期模拟赛题单 备战Python大学A组 第一题 【问题描述】 请问 2023 有多少个约数?即有多少个正整数,使得 2023 是这个正整数的整数倍。 【问题描述】 这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果…

计网Lesson15 - TCP可靠传输

文章目录 1. 停止等待ARQ协议2. 连续ARQ协议与滑动窗口协议 1. 停止等待ARQ协议 ARQ(Automatic Repeat–reQuest)自动重传请求 几种重传情况 发送端丢失 发送方过久没有接收到接收方的确认报,这种情况会触发超时重传机制,发送方…

Facebook的未来蓝图:数字社交的下一个篇章

在数字化时代,社交媒体已经成为人们日常生活中不可或缺的一部分。而在众多的社交媒体平台中,Facebook一直处于领先地位,不断探索着数字社交的新领域和新形式。随着科技的不断发展和社会的不断变革,Facebook正在谱写着数字社交的未…

JSON:简介与基本使用

目录 什么是JSON? JSON的基本结构 JSON的基本使用 在JavaScript中使用JSON 创建JSON对象 解析JSON字符串 生成JSON字符串 在其他编程语言中使用JSON 总结 什么是JSON? JSON,全称为JavaScript Object Notation,是一种轻量…

lv21 QT入门与基础控件 1

1 QT简介 QT是挪威Trolltech开发的多平台C图形用户界面应用程序框架 典型应用 2 工程搭建 2.1 新建ui工程 不要写中文路径 2.1 不勾选UI(主讲) 3 QT信号与槽机制 语法:Connect(A, SIGNLA(aaa()), B, SLOT(bbb()))…

代码随想录算法训练营day59 || 583. 两个字符串的删除操作,72. 编辑距离

动态规划之子序列,还是为了编辑距离做铺垫 | LeetCode:583.两个字符串的删除操作_哔哩哔哩_bilibili 动态规划终极绝杀! LeetCode:72.编辑距离_哔哩哔哩_bilibili 583. 两个字符串的删除操作 思路:返回使得s与t相同所…

k8s中基于alpine-3.7.0的pod无法解析域名问题

现象 在pod内无法解析指定域名 # 执行ping bash-4.4# ping xx-xx-svc-0.xxx-fcp.svc.cluster.local ping: bad address xx-xx-svc-0.xxx-fcp.svc.cluster.local排查经过 # 执行nslookup bash-4.4# nslookup xx-xx-svc-0.xxx-fcp.svc.cluster.local Server: 172.43.0…

27.HarmonyOS App(JAVA)可复用列表项的ListContainer

可复用列表项的ListContainer 简短的列表可以通过定向布局实现,但是如果列表项非常多,则使用定向布局就不再合适。如需要创建50个列表项的列表,那么用定向布局实现至少需要创建50个以上的组件了。然而,限于设备屏幕大小的限制,绝大多数组件不会显示在屏幕上,却会占据大量的内存…

C#使用QQ邮箱发送邮件

简介 在c#中发送邮箱我们只需要引入官方提供的命名空间 System.Net.Mail ,这个命名空间包含了一系列类,用于创建、配置和发送电子邮件消息。 这个命名空间中的一些主要类包括: MailMessage:表示一个电子邮件消息,包…

计网自顶向下:网络应用层【Web应用与HTTP协议】

目录 Web应用Web页URLWorld Wide Web 超文本传输协议——HTTP超文本C/S结构报文请求报文响应报文HTTP响应状态码try:在命令行里手工给web服务器发送请求 http连接的两种类型非持久(http1.0)持久(http1.1)▷ 流水线▷ 非…

重新安装VSCode后,按住Ctrl(or Command) 点击鼠标左键不跳转问题

重新安装VSCode后,按住Ctrl(or Command) 点击鼠标左键不跳转问题 原因:重新安装一般是因为相应编程语言的插件被删除了或还没有下载。 本次是由于Python相关的插件被删除了,因此导致Python无法跳转。 解决办法 在vs…

告别枯燥代码,Matplotlib学习网站让图表活起来!

介绍:Matplotlib是一个广泛使用的Python绘图库,专门用于创建高质量的2D图形。 Matplotlib的特点包括: 丰富的图表类型:支持多种图表类型,如线图、散点图、柱状图、直方图等,满足不同的数据可视化需求。 高度…

MySQL数据库进阶第五篇(锁)

文章目录 一、锁的概述二、全局锁三、表级锁四、元数据锁(meta data lock, MDL)五、意向锁六、行级锁七、行锁(Record Lock)八、间隙锁(Gap Lock)九、临键锁(Next-Key Lock)十、锁总…

beego代理前端web的bug

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 一、beego代理前端web的bug总结 一、beego代理前端web的bug *报错,为web压缩包index.html里面的注释被错误解析,删掉就行 2024/02/22 10:2…

低代码开发:数字赋能智能制造的未来

随着数字化转型的深入推进,智能制造已经成为我国制造业发展的重要方向。在这个过程中,低代码开发作为一种高效、便捷的编程方式,正逐渐成为企业数字化转型的得力助手。本文将探讨低代码开发在智能制造领域的应用及价值。 智能制造的挑战 随着…

C++面试基础 -操作系统-架构能力:如何高效利用CPU缓存

目录 局部性原理(Locality Principle) 数据结构的布局 缓存友好的算法 缓存大小和关联性 避免随机访问 使用缓存友好的数据结构 总结 高效利用CPU缓存是编写高性能C代码的关键之一。以下是一些在面试中可能会讨论到的方法。 局部性原理(Locality Principle) 时间局部性…

【C++】类和对象(2)

目录 1. 初始化列表 2.explicit关键字 3. Static成员 3. 友元 3.1友元函数 3.2友元类 4. 内部类 5.匿名对象 1. 初始化列表 在创建对象时,编译器通过调用构造函数,给对象中各个成员变量一个合适的初始值,但是这个过程并不能称为对对…

3,设备无关位图显示

建立了一个类Dib Dib.h #pragma once #include “afx.h” class CDib :public CObject { public: CDib(); ~CDib(); char* GetFileName(); BOOL IsValid(); DWORD GetSize(); UINT GetWidth(); UINT GetHeight(); UINT GetNumberOfColors(); RGBQUAD* GetRGB(); BYTE* GetDat…