大家好,欢迎来到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中的函数和数组一样, 都是引用数据类型(对象类型)
- 既然是一种数据类型, 所以也可以保存到一个变量中;
- 将一个函数保存到一个变量中;将来可以通过变量名称找到函数并执行函数;
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之前如何定义函数
- function 函数名称(形参列表){
需要封装的代码;
}
- 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