IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> JavsScript基础篇之函数定义的几种不同方式 -> 正文阅读

[JavaScript知识库]JavsScript基础篇之函数定义的几种不同方式

回顾

在上一篇中我们聊了聊数组的创建和获取数组中元素的方法,同时上一篇中我们主要利用数组来处理一些基本的运算,提升一下逻辑能力,对于刚入门的来说这些还是挺难的。不过没关系,你可以看看多缕一缕它们之间的关系,不需要死记硬背,以理解为主。慢慢熟悉就可以,主要还需要自己手动的多敲几遍。

这一篇中我们主要将函数的概念和函数声明的几种方式,牵扯到的还有函数中的形参和实参传参的问题,除此之外我们还会说一说 最常用 return 的作用,以及函数中处理参数的 arguments等。

函数

函数的概念

函数:封装了一段可以被重复调用执行的代码块,通过此代码块可以实现大量代码的重复使用。

函数的使用

声明函数

// 声明一个函数
function name() {
  console.log('你调用了!我要执行了')
}
// 调用函数
name()

需要注意的是:

  • function 声明函数的关键字全部小写

  • 函数是做某些事情,函数名一般使用动词 例如:sayHi

  • 函数不调用,自己不执行。

  • 调用函数 => 函数名()

函数的参数

  • 形参:形式上的参数,在函数定义的时候传递的参数,当前并不知道是什么

  • 实参:实际的参数,函数调用的时候传递的参数,实参是传递给形参的

  • 注意:多个参数之间用逗号 “,” 隔开

作用:因为在函数的内部,某些值不能固定,所以我们可以通过参数在调用函数时传递不同的值进去

注意:需要注意的是,前端中任何的符号,例如 逗号(,) 冒号(:)等 都是英文状态下的。

// 在创建函数的时候 先定义一些 形参
function person (name, age, sex) {
  // 输出这些参数,这些输出的值取决于你调用时传递的实参
  console.log(name)
  console.log(age)
  console.log(sex)
}

// 调用的时候传递的实参
person('Rose', 18, '女')

在这里插入图片描述

函数的形参和实参个数不匹配问题
  • 实参个数等于形参个数:输出正确结果

  • 实参个数多余形参个数:只取到形参的个数

  • 实参个数小于形参个数:多的形参定义为 undefined,结果为NaN

function sum(num1, num2) {
  console.log(num1 + num2)
}
sum(1, 2)  // 形参个数和实参个数相等,输出正确结果
sum(1, 3, 2)   // 实参个数多余形参个数,只取到形参的个数
sum(1)     // 实参个数小于形参个数,多的形参定义为 undefined,结果为NaN

在这里插入图片描述

函数的返回值

函数只是实现了某些功能,最终的结果需要返回给函数的调用者

例如:

// 在往后的工作或者学习中,函数中经常会用到 return,这个就是返回给调用者数据的
function getSum (num1, num2) {
  return num1 + num2
}

// 将结果打印出来
console.log(getSum(1, 2))

可以来看看 return 在工作场景中的真实例子,借助于三元表达式来判断:

在这里插入图片描述

不过在 return 中需要注意的是如下几点:

  • return 后面的代码不会被执行

  • return 只能是返回一个值,以最后一个为准

  • 如果需要返回多个的话,需要数组

返回多个值,例如:

// 声明和传参
function getSum (num1, num2) {
  return [num1 + num2, num1 * num2, num1 - num2]
}

// 调用,传递实参
console.log (getSum(2, 1))

arguments 的使用

arguments:它的作用在于当我们不确定有多少个参数传递的时候,可以用 arguments 来获取,在 js 中 arguments 实际上是它当前函数的一个内置对象,所有的函数都内置了一个arguments对象,arguments 中存储了传递的所有实参,arguments中存储的是伪数组

伪数组:

  • 具有数组 length 的属性

  • 按照索引的方式存储

  • 它没有真正数组的方法 pop()、push()

// arguments 有些时候并不确定多少个参数,让arguments代替
function name() {
  console.log(arguments);
}
name (1,2,3)

在这里插入图片描述

函数举例

利用函数封装 方法

案例1:封装一个累加和

// 求 1~100 之间的和
var sum = 0
function setSum (num1, num2) {
  for (var i = num1; i <= num2; i++) {
    sum += i
  }
  console.log(sum);
}
setSum(1,100)
setSum(1,1000)

案例2:封装一个翻转任意数组

// 利用函数的方法反转任意数组
function reverse(arguments) {
  var newArr = []
  for (var i = arguments.length - 1; i >= 0; i--) {
    newArr[newArr.length] = arguments[i]
  }
  return newArr
}
console.log(reverse([1, 2, 3, 4, 5, 6, 7, 8, 9, 10]));
console.log(reverse([1, 2, 3, 4, 5]));
函数可以调用另外一个函数

在函数中也可以调用另外一个函数,在正常的情况下,执行顺序是依次执行的。可以看看下面的例子 你看懂了吗,

重点:不调用函数不执行

// 函数调用另一个函数   输出 123
function fn1() {
  console.log(2)
}
function fn2() {
  console.log(1);
  fn1();
  console.log(3);
}

fn2()

在这里插入图片描述

函数声明的两种方式

在函数声明中,上面说的这种是利用关键字声明自定义函数,称之为:命名函数,函数声明还有另外一种方式:匿名函数,也叫做函数表达式

// 函数的两种声明方式
// 1、利用函数关键字自定义函数(命名函数)
function name() {
  console.log('你调用了!我要执行了')
}
name ()

// 2、函数表达式(匿名函数)
var 变量名 = function () {}

// 第二种声明函数
var fn = function () {
  console.log('我是函数表达式')
}
// 和之前的声明变量很类似
var arr = 10

在这里插入图片描述

好了,今天关于函数的这一篇就说完了,函数是未来常用的一种定义方式,可以多加练习,尝试的利用函数封装一些方法。有什么问题,欢迎留言讨论~

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-11-23 12:15:16  更:2021-11-23 12:16:21 
 
开发: 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/4 10:38:41-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码