【JS基础】1.函数、匿名函数、回调函数、IIFE(立即执行函数)

【JS基础】1.函数、匿名函数、回调函数、IIFE(立即执行函数)

1. 认识函数

  • 函数到底是什么?
    • 函数其实就是某段代码的封装,这段代码帮助我们完成某一下功能
    • JS引擎中有一些已经提供的函数
    • 我们也可以编写属于自己的函数
  • 函数使用的步骤
    • 声明函数:封装成独立的功能快
    • 调用函数:享受封装的成果

2. 声明函数和调用函数

  • 使用function关键字
function foo() {console.log('这是函数声明')
}
  • 函数的返回值
    • 使用return来返回结果
    • 如果函数没有返回语句,会有默认的返回值undefined
    • 如果有return语句,但没有返回任何东西,返回值为undefined
    • return语句后面的代码不会执行
  • arguments参数
    • 默认情况下,arguments对象是所有(非箭头)函数中可用的局部变量
    • arguments是一个object类型(array-like)伪数组
function bar() {console.log(arguments)// [Arguments] { '0': 1, '1': 2, '2': '测试', '3': { name: '张三' } }
}bar(1, 2, '测试', { name: '张三' })

3. 函数表达式

  • 函数表达式的写法
// 函数表达式的写法
var baz = function () {console.log('这是用函数表达式创建的函数')
}
  • 在JS中函数只是一种特殊的值

  • 无论函数是怎么创建的,都是一种特殊的值

  • 函数表达式和函数声明的区别

    • 函数表达式是在代码到达执行的时候创建
    • 函数声明在被定义之前就可以使用

4. JavaScript头等函数

  • 头等函数,指函数可以作为函数的参数、返回值、赋值给变量、或者存储在数据结构中
  • 通常对头等公民的变成方式,称之为函数式变成
// 定义一个函数
function foo() {console.log('这是函数foo内部')function fooSon() {console.log('这是foo的子函数')}return fooSon
}var bar = function (fn) {console.log(`这是函数bar`)return fn()
}// 函数可以赋值给变量
var baz = foo// 将函数baz已参数的形式传递给bar
bar(baz)
// 这是函数bar
// 这是函数foo内部// 调用foo函数
console.log('调用foo')
var returnFun = foo()
returnFun()// 函数可以存储在数据结构中
var obj = {name: '张三',age: 18,goBack: function (params) {console.log('我能返回')}
}

5. 回调函数

  • 我们可以将一个函数传递给函数
function foo(type, callback) {console.log(`这是传递的参数${type}`)setTimeout(function () {console.log('foo函数处理type中')type++callback(type)}, 2000)
}// 显然 foo是一个异步函数,如果我们需要获取最后的type值
// 获取foo处理过的type
function getFooType(type) {console.log(`获取到了type${type}`)
}foo(66, getFooType)
// 这是传递的参数66
// foo函数处理type中
// 获取到了type67
  • 当然,我们也可以改造成匿名函数更方便使用
function foo(type, callback) {console.log(`这是传递的参数${type}`)setTimeout(function () {console.log('foo函数处理type中')type++callback(type)}, 2000)
}// 显然 foo是一个异步函数,如果我们需要获取最后的type值
foo(66, function (res) {console.log(`获取的返回值${res}`)
})
// 这是传递的参数66
// foo函数处理type中
// 获取的返回值67

6 立即执行函数

  • 立即执行函数IIFE立即调用函数表达式
  • 立即执行函数会创建一个独立的上下文,避免外界访问和修改内部的变量
<button>按钮1</button>
<button>按钮2</button>
<button>按钮3</button>
<button>按钮4</button><script>var btns = document.querySelectorAll('button')for (var i = 0; i < btns.length; i++) {btns[i].addEventListener('click', function () {console.log(`点击了第${i}个button`)})}
</script>

显然,在上面的代码中,由于使用var来声明的i,每次点击后得到的i都是4,我们利用立即执行函数改造一下

var btns = document.querySelectorAll('button')
for (var i = 0; i < btns.length; i++) {;(function (i) {btns[i].addEventListener('click', function () {console.log(`点击了第${i + 1}个button`)})})(i)
}

立即执行函数,可以有入参,返回值

  • 立即执行函数的其他写法
// 常规写法
var result = (function (text) {var result = {name: '张三',age: 18,action: foo}function foo() {console.log(`匿名函数里面的函数`)}console.log(`这是定义的匿名函数`)console.log(`接收到的参数${text}`)return result
})('这是形参')
result.action()// 表达式写法 + -都是表达式,函数也是一个特殊的值
+function foo(){}()

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

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

相关文章

十大经典排序算法之插入排序。

插入排序 (Insertion Sort) ​ 插入排序&#xff08;Insertion Sort&#xff09;是一种简单直观的排序算法&#xff0c;它的基本思想是逐步构建最终的排序列表&#xff0c;每次将一个未排序的元素插入到已排序的部分的适当位置。 插入排序的基本步骤如下&#xff1a; 首先&a…

第十五届蓝桥杯省赛第二场C/C++B组E题【遗迹】题解

解题思路 错解 贪心&#xff1a;每次都移动至当前最近的对应方块上。 反例&#xff1a; s s s abxac t t t abac 贪心结果&#xff08;下标&#xff09; 0 → 1 → 0 → 4 0 \rightarrow 1 \rightarrow 0 \rightarrow 4 0→1→0→4&#xff0c;答案为 5 5 5。 正确结…

仿真-Carla初识-运行

目录 0.简介1.导入地图AdditionalMaps2.Carla运行 0.简介 carla-github下载 python是通过ip127.0.0.1&#xff0c;port 2000与Carla进行本地通讯的&#xff08;脚本与CarlaUE4.exe在同一台电脑&#xff09;&#xff0c;下面可能是大家可能会遇到的问题&#xff1b; 代码中端口…

VMware配置centos虚拟机实现内网互通

VMware配置centos虚拟机实现内网互通 一、安装无桌面模式 环境说明&#xff1a; VMWare版本&#xff1a;VMware Workstation 17 Pro Centos版本&#xff1a;CentOS-7.9-x86_64-DVD-2009.iso 一键下载本文资源包 1. 安装虚拟机 下面是创建具体步骤,其中需要注意的是&#xff1…

说说2024年暑期三下乡社会实践工作新闻投稿经验

作为一名在校大学生,我有幸自去年起参与学院组织的暑期大学生三下乡社会实践团活动。这项活动不仅是我们深入基层、服务社会的重要平台,也是展现当代大学生风采、传递青春正能量的有效途径。然而,如何将这些生动鲜活的实践故事、感人至深的瞬间传播出去,让更多人了解并受到启发…

LeetCode54. 螺旋矩阵

LeetCode54.螺旋矩阵 题解思路 代码 class Solution { public:vector<int> spiralOrder(vector<vector<int>>& matrix) {vector<int> res;int n matrix.size();// 行int m matrix[0].size(); // 列vector<vector<bool>> st(n, v…

懂技术不代表懂互联网

作为一个技术开发者&#xff0c;也就是程序员&#xff0c;个人一直认为自己是一个互联网从业者&#xff0c;也认为自己懂互联网。但是&#xff0c;直到今天突然才发现&#xff0c;自己根本不懂互联网&#xff0c;自己认为的懂互联网只是从技术人员的角度理解互联网&#xff0c;…

【JAVA】PO、VO、DAO、BO、DTO、POJO你分得清吗?

在Java开发中&#xff0c;PO、VO、DAO、BO、DTO、POJO这些词汇是比较常见的&#xff0c;每个术语都有其特定的含义和用途。下面是它们的具体区别&#xff1a; 名称简要概况用途和特定PO (Persistence Object) 持…

2024.4.25力扣每日一题——总行驶距离

2024.4.25 题目来源我的题解方法一 模拟 题目来源 力扣每日一题&#xff1b;题序&#xff1a;2739 我的题解 方法一 模拟 当mainTank还剩5升及以上的油&#xff0c;直接一次性减5升&#xff0c;距离加50&#xff0c;然后看additionalTank是否还有油&#xff0c;若有减1&…

数据结构与算法学习笔记五--串(C++)

目录 前言 一、定义 二、串的表示和实现 1.定长顺序存储表示 1.定义 2.串拼接 3.求子串 4.完整代码 2.堆分配存储表示 1.定义 2.求串长 3.串比较 4.清空s串&#xff0c;释放空间 5.串拼接 6.求子串 7.完整代码 3.串的块链存储表示 1.定义 2.生成串 3.生成串…

revit\navisworks各种安装问题

You have entered a nonvalid serial number &#xff0c;怎么都不给你一个机会输出序列号&#xff0c;怎么办&#xff1f; step1: C:\Program Files (x86)\Common Files\Autodesk Shared\AdskLicensing目录下找到uninstall.exe&#xff0c;右键管理员模式运行&#xff0c;会…

新媒体运营-----短视频运营-----PR视频剪辑----文本与图形

新媒体运营-----短视频运营-----PR视频剪辑-----持续更新(进不去说明我没写完)&#xff1a;https://blog.csdn.net/grd_java/article/details/138079659 文章目录 1. 文本样式2. 文字与图形样式的配合3. 图形模版4. AE创建动画模版导出到PR5. PS图稿导出至PR创建运动图形6. PR图…

mysql报错 之 报错:Duplicate entry 字段 for key ‘表名.idx_字段’

一、问题操作 Mysql 进行insert 操作&#xff0c;报错&#xff1a;Duplicate entry 字段 for key ‘表名.idx_字段’ 原因解析&#xff1a;idx 是做的索引键&#xff0c;是具有唯一性 二、问题原因&#xff08;三种情况&#xff0c;当前我遇到的情况是第一种&#xff09; 当…

文件包含漏洞基础

php 中的文件包含函数&#xff1a; incude &#xff1a; require incude_once require_once 为了减少重复性代码的编写&#xff1b; 任意后缀的文件当中只要存在 php 代码就会被当作 php 执行&#xff1b; 本质&#xff1a;由于包含的文件不可控&#xff0c;导致文件包含…

07节-51单片机-矩阵键盘

文章目录 1矩阵键盘原理2.扫描的概念3.弱上拉4.实战-实现矩阵键盘对应按钮按下显示对应值4.1配置代码模板 5.键盘锁 1矩阵键盘原理 在键盘中按键数量较多时&#xff0c;为了减少I/O口的占用&#xff0c;通常将按键排列成矩阵形式 采用逐行或逐列的“扫描”&#xff0c;就可以读…

深浅拷贝及其现代写法

#include<iostream> using namespace std; class Person { public://默认构造Person(){cout << "Person()" << endl;}//有参构造函数Person(int age,int height){m_age age;m_height new int(height);cout << "Person(int age, int h…

【ZYNQ】zynq启动模式及程序固化

一、前言 由于zynq含有arm cpu ,其启动模式由ps主导&#xff0c;与纯逻辑的fpga不相同&#xff0c;此处做一个记录。 二、zynq启动模式 关于zynq的启动模式详细内容可以参考官方文档&#xff1a;ug585-Zynq 7000 SoC Technical Reference Manual&#xff0c;第六章。 2.1 启…

12(第十一章,数据仓库和商务智能)

目录 概述 目标和原则 基本概念 商务智能 数据仓库 数据仓库建设方法 数据仓库架构组件 加载处理方式 1、历史数据 2、批量变更数据捕获&#xff08;CDC&#xff09; 3、准实时和实时数据加载 活动 运营分析应用 方法 数据仓库构建 架构演进 数据处理过程 数…

Nacos分布式配置中心和服务注册中心

分布式配置中心 Nacos Spring Cloud 快速开始 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation&qu…

第一届长城杯半决赛wp和AWD笔记

目录 AWD 渗透 cfs 单节点1 AWD笔记 AWD工具 文件比较工具 Web漏洞扫描工具 waf工具 代码审计工具 批量网站备份文件泄露扫描工具 cms通杀漏洞的利用 通杀脚本和批量提交flag脚本 防御流程 攻击流程 注意 AWD 解题思路] 首先就是fscan快速扫描对应C段&#xf…