报一丝现在才解决完一推破事和实验,可把我累鼠了。继续是JS基础,这两天必须把基础都学习完!接着就可以开启web api了。
目录
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>
总结:
-
声明(定义)函数时的参数没有数量限制,当有多个参数时使用
,分隔 -
调用函数传递的实际参数要与函数声明时的参数顺序一致
形参和实参
形参:声明函数时写在函数名右边小括号里的叫形参(形式上的参数)
实参:调用函数时写在函数名右边小括号里的叫实参(实际上的参数)
形参可以理解为是在这个函数内声明的变量 (比如 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>
总结:
-
在函数体中使用return 关键字能将内部的执行结果交给函数外部使用
-
函数内部只能出现 1 次 return ,并且 return 下一行代码不会再被执行,所以return 后面的数据不要换行写
-
return会立即结束当前函数
-
函数可以没有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