JS-9-函数

JS-9-函数一 JavaScript 函数 1 什么是函数 函数是专门用于封装代码的 函数是一段可以随时被反复执行的代码块 2 函数格式 function 函数名称 形参列表 被封装的代码 3 函数定义步骤 1 1 书写函数的固定格式 1

大家好,欢迎来到IT知识分享网。

一、JavaScript函数
1.什么是函数?

函数是专门用于封装代码的, 函数是一段可以随时被反复执行的代码块;

2.函数格式

function 函数名称(形参列表){

被封装的代码;
}

3.函数定义步骤

1.1 书写函数的固定格式

1.2 给函数起一个有意义的名称

1.3 确定函数的形参列表

看看使用函数的时候是否需要传入一些辅助的数据;

1.4 将需要封装的代码拷贝到{}中

1.5 确定函数的返回值

可以通过return 数据; 的格式, 将函数中的计算结果返回给函数的调用者;
1.一个函数可以有形参也可以没有形参(零个或多个) ;
2 什么是形参? 定义函数时函数()中的变量我们就称之为形参;

4.返回值

1.一个函数可以有返回值也可以没有返回值;

2.函数没有通过return明确返回值, 默认返回undefined;

3.return的作用和break相似, 所以return后面不能编写任何语句(永远执行不到);

5.调用函数时实参的个数和形参的个数可以不相同

什么是实参? 调用函数时传入的数据我们就称之为实参;

6.JavaScript中的函数和数组一样, 都是引用数据类型(对象类型)
  1. 既然是一种数据类型, 所以也可以保存到一个变量中;
  2. 将一个函数保存到一个变量中;将来可以通过变量名称找到函数并执行函数;
let say = function() { console.log("hello world"); } say(); 

二、arguments

1.因为console.log();也是通过()来调用的, 所以log也是一个函数;

2.log函数的特点:可以接收1个或多个参数;

3.为什么log函数可以接收1个或多个参数:内部的实现原理就用到了arguments;

4.arguments的作用 :保存所有传递给函数的实参;

注意点: 每个函数中都有一个叫做arguments的东东;// arguments其实是一个伪数组;

例:

function getSum() { let sum = 0; for (let i = 0; i < arguments.length; i++){ let num = arguments[i]; // console.log(num); // 10 20 30 sum += num; // sum = sum + num; } return sum; } let res = getSum(10, 20, 30, 40); console.log(res); 

三、JavaScript-函数扩展运算符

1.扩展运算符在等号左边, 将剩余的数据打包到一个新的数组中;

注意点: 只能写在最后;

let [a, ...b] = [1, 3, 5]; a = 1; b = [3, 5];

2.扩展运算符在等号右边, 将数组中的数据解开;

let arr1 = [1, 3, 5]; let arr2 = [2, 4, 6]; let arr = [...arr1, ...arr2]; let arr = [1, 3, 5, 2, 4, 6]; //相当于拼接 

3.扩展运算符在函数的形参列表中的作用:
将传递给函数的所有实参打包到一个数组中;
注意点: 和在等号左边一样, 也只能写在形参列表的最后;

function getSum(a, ...values)


四、函数形参默认值,函数作为参数和返回值
1. 函数形参默认值
function getSum(a, b) { > 在ES6之前可以通过逻辑运算符来给形参指定默认值; 格式: 条件A || 条件B 如果条件A成立, 那么就返回条件A 如果条件A不成立, 无论条件B是否成立, 都会返回条件B a = a || "指趣学院"; b = b || "知播渔教育"; console.log(a, b); } getSum(123, "abc"); 
> 从ES6开始, 可以直接在形参后面通过=指定默认值; 注意点: ES6开始的默认值还可以从其它的函数中获取; function getSum(a = "指趣学院", b ="知播渔教育") { ...} 
2. 函数作为参数和返回值:

(1)将函数作为其他函数的参数

function test(fn) { // let fn = say; fn(); } test(say); 

(2)将函数作为其他函数的返回值

function test() { // 注意点: 在其它编程语言中函数是不可以嵌套定义的, // 但是在JavaScript中函数是可以嵌套定义的 let say = function () { console.log("hello world"); } return say; } let fn = test(); // let fn = say; fn(); 

五、匿名函数
1.什么是匿名函数?

匿名函数就是没有名称的函数;

匿名函数:

function() { console.log("hello lnj"); } 
2.匿名函数的注意点

匿名函数不能够只定义不使用;

3.匿名函数的应用场景

3.1 作为其他函数的参数

 function test(fn) { // let fn = say; fn(); } test ( function () { console.log("hello world"); } ) ; 

3.2 作为其他函数的返回值

function test() { return function () { console.log("hello abc"); }; } let fn = test(); // let fn = say; fn(); 

3.3 作为一个立即执行的函数

注意点: 如果想让匿名函数立即执行, 那么必须使用()将函数的定义包裹起来才可以; (function () { console.log("hello it666"); }) ( ); 

六、箭头函数
1.什么是箭头函数?

箭头函数是ES6中新增的一种定义函数的格式;

目的: 就是为了简化定义函数的代码;

2.在ES6之前如何定义函数
  1. function 函数名称(形参列表){

    需要封装的代码;

}

  1. let 函数名称 = function(形参列表){

    需要封装的代码;

}

3.从ES6开始如何定义函数

let 函数名称 = (形参列表) =>{

需要封装的代码; 

}

4.箭头函数的注意点

4.1 在箭头函数中如果只有一个形参, 那么()可以省略;

4.2 在箭头函数中如果{}中只有一句代码, 那么{}也可以省略;


七、递归函数
1.什么是递归函数?

递归函数就是在函数中自己调用自己, 我们就称之为递归函数;递归函数在一定程度上可以实现循环的功能;

2.递归函数的注意点
function login() { // 1.接收用户输入的密码 let pwd = prompt("请输入密码"); // 2.判断密码是否正确 if(pwd !== ""){ login(); } // 3.输出欢迎回来 alert("欢迎回来"); } login(); 

-End

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/144192.html

(0)
上一篇 2025-04-28 15:10
下一篇 2025-04-28 15:20

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信