JavaScript学习第六天:函数

报一丝现在才解决完一推破事和实验,可把我累鼠了。继续是JS基础,这两天必须把基础都学习完!接着就可以开启web api了。

目录

JavaScript学习Day6

函数

声明和调用

声明(定义)

调用

参数

形参和实参

返回值


JavaScript学习Day6

理解封装的意义,能够通过函数的声明实现逻辑的封装,知道对象数据类型的特征,结合数学对象实现简单计算功能。

  • 理解函数的封装的特征

  • 掌握函数声明的语法

  • 理解什么是函数的返回值

  • 知道并能使用常见的内置函数

函数

理解函数的封装特性,掌握函数的语法规则

函数是被设计为执行特定任务的代码块。

声明和调用

函数可以把具有相同或相似逻辑的代码"包裹"起来,通过函数调用执行这些被"包裹"的代码逻辑,这么做的优势是有利于精简代码方便复用

声明(定义)

声明(定义)一个完整函数包括关键字、函数名、形式参数、函数体、返回值5个部分

调用

声明(定义)的函数必须调用才会真正被执行,使用 () 调用函数。

html 复制代码
 <!DOCTYPE html>
 <html lang="en">
 <head>
   <meta charset="UTF-8">
   <title>JavaScript 基础 - 声明和调用</title>
 </head>
 <body>
   <script>
     // 声明(定义)了最简单的函数,既没有形式参数,也没有返回值
     function sayHi() {
       console.log('嗨~')
     }
     
     // 函数调用,这些函数体内的代码逻辑会被执行 如果不调用 函数自己不会执行
     // 语法 函数名()    
     sayHi()
     // 可以重复被调用,多少次都可以
     sayHi()
   </script>
 </body>
 </html>

注:函数名的命名规则与变量是一致的,并且尽量保证函数名的语义。尽量使用小驼峰命名法,前缀为动词,常用的前缀可以是:

其实,我们曾经使用的alert()parseInt()push()等都是对函数的调用

函数的复用代码和循环重复代码的不同:

  • 循环代码写完即执行,不能很方便地控制执行位置

  • 函数随时调用,随时执行,可重复调用

小案例: 小星星

javascript 复制代码
    <script>
         // 函数声明
         function sayHi() {
             // document.write('hai~')
             document.write(`*<br>`)
             document.write(`**<br>`)
             document.write(`***<br>`)
             document.write(`****<br>`)
             document.write(`*****<br>`)
             document.write(`******<br>`)
             document.write(`*******<br>`)
             document.write(`********<br>`)
             document.write(`*********<br>`)
         }
         // 函数调用
         sayHi()
         sayHi()
         sayHi()
         sayHi()
         sayHi()
     </script>

参数

通过向函数传递参数,可以让函数更加灵活多变,参数可以理解成是一个变量。

声明(定义)一个函数的参数列表:

  • 传入数据列表

  • 声明这个函数需要传入几个数据

  • 多个数据用逗号隔开

语法:

javascript 复制代码
 function 函数名(参数列表) {
   函数体
 }

调用函数的方法就是:

javascript 复制代码
 函数名(传递的参数列表)

比如,我们声明一个打招呼的函数:

html 复制代码
 <!DOCTYPE html>
 <html lang="en">
 <head>
   <meta charset="UTF-8">
   <title>JavaScript 基础 - 函数参数</title>
 </head>
 <body>
 ​
   <script>
     // 声明(定义)一个功能为打招呼的函数
     // function sayHi() {
     //   console.log('嗨~')
     // }
     // 调用函数
     // sayHi()
   
     // 这个函数似乎没有什么价值,除非能够向不同的人打招呼
     // 这就需要借助参数来实现了
     function sayHi(name) {
       // 参数 name 可以被理解成是一个变量
       console.log('嗨~' + name)
     }
 ​
     // 调用 sayHi 函数,括号中多了 '小明'
     // 这时相当于为参数 name 赋值了
     sayHi('小明')// 结果为 嗨~小明
 ​
     // 再次调用 sayHi 函数,括号中多了 '小红'
     // 这时相当于为参数 name 赋值了
     sayHi('小红') // 结果为 嗨~小红
   </script>
 </body>
 </html>

总结:

  1. 声明(定义)函数时的参数没有数量限制,当有多个参数时使用 , 分隔

  2. 调用函数传递的实际参数要与函数声明时的参数顺序一致

形参和实参

形参:声明函数时写在函数名右边小括号里的叫形参(形式上的参数)

实参:调用函数时写在函数名右边小括号里的叫实参(实际上的参数)

形参可以理解为是在这个函数内声明的变量 (比如 num1 = 10)实参可以理解为是给这个变量赋值

开发中尽量保持形参和实参个数一致

html 复制代码
 <!DOCTYPE html>
 <html lang="en">
 <head>
   <meta charset="UTF-8">
   <title>JavaScript 基础 - 函数参数</title>
 </head>
 <body>
   <script>
     // 声明(定义)一个计算任意两数字和的函数
     // 形参 x 和 y 分别表示任意两个数字,它们是两个变量
     function count(x, y) {
       console.log(x + y);
     }
     // 调用函数,传入两个具体的数字做为实参
     // 此时 10 赋值给了形参 x
     // 此时 5  赋值给了形参 y
     count(10, 5); // 结果为 15
   </script>
 </body>
 </html>

注:如果在调用函数的时候没有给实参,那么参数默认是undefined,这时候得到的结果通常为 NAN

因此,我们可以做一个改进,在定义形参的时候顺便给一个形参默认值

javascript 复制代码
 function count(x = 0, y = 0) {
   console.log(x + y);
 }
 count()

当然,这个默认值只会在缺少实参参数传递时才会被执行,所以有参数会优先执行传递过来的实参。

当然,实参不一定是一个具体的数值,实参也可以是变量,由用户来决定它的值:

javascript 复制代码
 let n = +prompt('请输入第一个值')
 let m = +prompt('请输入第二个值')
 getSum(n, m)

返回值

函数的本质是封装(包裹),函数体内的逻辑执行完毕后,函数外部如何获得函数内部的执行结果呢?要想获得函数内部逻辑的执行结果,需要通过 return 这个关键字,将内部执行结果传递到函数外部,这个被传递到外部的结果就是返回值。

其实在前面,我们已经接触了很多函数具备返回值:

javascript 复制代码
let result = prompt('请输入你的年龄')
let result = parseInt('111')

只是这些函数是JS底层内置的,我们可以直接使用

当然,有些函数没有返回值:

javascript 复制代码
alert('我是弹框')

因此,我们需要根据需求,来设定需不需要返回值。但很多情况下,我们是需要返回值的。

当函数需要返回值的时候,应该用return关键字

语法:return 数据,比如:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>JavaScript 基础 - 函数返回值</title>
</head>
<body>

  <script>
    // 定义求和函数
    function count(a, b) {
      let s = a + b
      // s 即为 a + b 的结果
      // 通过 return 将 s 传递到外部
      return s
    }
    // 调用函数,如果一个函数有返回值
		count(5, 12) //相当于把 s 赋值给了 count()
    // 那么可将这个返回值赋值给外部的任意变量
    let total = count(5, 12)
  </script>
</body>
</html>

总结:

  1. 在函数体中使用return 关键字能将内部的执行结果交给函数外部使用

  2. 函数内部只能出现 1 次 return ,并且 return 下一行代码不会再被执行,所以return 后面的数据不要换行写

  3. return会立即结束当前函数

  4. 函数可以没有return ,这种情况默认返回值为 undefined

但是,由于每个函数只能出现一次return,那么我如何让函数一次返回多个值呢?

其实很简单,让函数返回一个数组就可以了,我们之前就学过,数组能一次存储多个数据,那么同时,使用return返回一个数组也能返回多个数据。

比如,求数组中的最大值和最小值:

javascript 复制代码
function getMaxMin(arr = []) {
	  let max = arr[0]
    let min = arr[0]
    for (let i = 1; i < arr.length; i++) {
      if (arr[i] > max) {
        max = arr[i]
      }
      if (arr[i] < min) {
        min = arr[i]
      }
    }
    // 一次返回多个值 返回一个数组
    return [max, min]
}

let newArr = getMaxMin([11, 32, 4, 56, 24])
console.log('数组的最大值是:${newArr[0]},最小值是:${newArr[1]}')

注意:关于断点调试,想要进入函数内部查看运行过程,需要按键F11

相关推荐
LEEBELOVED2 小时前
R语言高效数据处理-变量批量统计检验
1024程序员节·r语言高效处理数据
源来猿往3 小时前
基于window/ubuntu安装rknn-toolkit2【docker】
docker·1024程序员节·rknn-toolkit2
生物小卡拉3 小时前
指定列交集内容合并-Rscript_v1.0
笔记·学习·r语言
千禧皓月3 小时前
【Diffusion Model】发展历程
人工智能·深度学习·diffusion model·1024程序员节
shandianchengzi3 小时前
【工具】Scrcpy|安卓投屏电脑的开源工具Scrcpy的安装及看电视注意事项
安卓·1024程序员节·投屏·电视·scrcpy
趙小贞3 小时前
UART 串口协议详解与 STM32 实战实现
stm32·单片机·嵌入式硬件·通信协议·1024程序员节
不惑_3 小时前
如何在 CentOS 9 Stream 服务器上安装 MySQL?
1024程序员节
今天背单词了吗9803 小时前
Spring Boot+RabbitMQ 实战:4 种交换机模式(Work/Fanout/Direct/Topic)保姆级实现
java·spring·中间件·rabbitmq·1024程序员节