JS函数相关

1. 函数

分为系统函数和自定义函数

函数:是一个功能体,需要提供若干个数据,返回处理的结果;用于封装重复执行的代码。

Number() / parselnt() / parseFloat() / alert() / prompt().

 
(1) 创建普通函数


function函数名称(){
    函数体——封装的重复执行的代码
}
//调用
函数名称()
// 调用后会执行函数体中的代码

 练习:创建函数,在函数体中封装计算1100之间所有整数的和并打印,调用多次

function sum(){
    for(var i=0,result=0;i<=100;i++){
        result+=i
}console.log(result)
}sum()

 

 

(2) 创建带有参数的函数

function 函数名称(参数列表){//用于接收传递的数据
    函数体
}
//调用
函数名称(参数列表)  //实际传递的数据


 参数:创建函数时的参数称为形参,调用函数时的参数称为实参,实参会赋值给形参,实参的数量可以是0个或者多个,如果形参未被赋值,则为undefined。多个参数之间用逗号隔开。

 

练习:创建函数,计算任意两个年份之间的闰年个数,调用多次
 

function getYear(num1, num2){
    for (var i= num1, sum= 0; i <= num2; i++){
        if(i % 4 === 0 && i % 100 !== 0 || i % 400 === 0) {
            sum++
        }
    }
        console.log(sum);
}
getYear(2000, 2012)
getYear(2000,2020)

 

 

 

(3) 创建带有返回值的函数

function 函数名称(参数列表){
    函数体
    return值; //返回值,函数调用后得到的结果
}
//调用
函数名称(参数列表)


return作用是返回函数调用后的结果;如果函数中没有return或者return后没有加任何值,则返回的结果为undefined; return 执行后,就会结束函数的执行。

 

练习:创建函数getMax2,传递任意三个数字,返回最大值。

function getMax2(a,b,c){
    if(a > b && a > c) return a
    else if (b > c) return b
    else if  return c
}
let r= getMax2(1,2,3)
console.1og(r);

 

对比return和break

break用于循环和switch-case,作用是结束循环或者switch-case语句的执行。

return用于函数中,结束函数的执行。

 

 

 

--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

 

 2. 变量作用域


  作用域:起作用的范围


全局作用域:在函数外使用var声明的变量,可以在任何的作用域下访问到,称为全局变量。
函数作用域:在函数内使用var声明的变量,只能在当前的作用域下访问到,称为局部变量。

在函数内,不加var声明的变量自动是全局变量,但是不推荐,后期严格模式下会报错。

 

function fun(){
    var m1=m2=m3=5;
// m3=5//全局
// m2=m3//全局
//var m1=m2;//局部变量
}
fun();
console.log(m3);//5
console.log(m2);//5
console.log(m1);//报错

 

 

变量的提升

JS程序执行前,会将var声明的变量提升到所在作用域的最前边,赋值不提升。

//全局变量m
var m=5;
function bar(m){
//m是参数,局部变量
//var m=6;
//修改的是参数m,对全局没有任何影响
m=m+7;
}
bar(6);
//访问全局m
console.log(m); //5

 

 

3. 函数的作用域


函数的可访问范围
全局函数:在全局作用域下创建的函数,可以在任何的作用域下调用
局部函数:在函数作用域下创建的函数,只能在当前作用域下调用

 

 

函数提升

JS程序执行前,会将function关键字创建的函数提升到所在作用域的最前边,会整体提升。

 

 

4. 递归

在函数内调用自身,本身是一个死循环

如何使用?

要有结束条件,要结合着return

递归属于CPU密集型算法

//使用递归计算1~n之间所有整数的和
function getSum(n){
    /结束条件:当n为1的时候,返回1
    if(n===1){
    return 1;
}
//前n个数的和,等价于n +前n-1项的和
    return n+getSum(n-1);
}
    var r=getSum( 100);
    console.log(r);


 

 

 

5. 匿名函数

没有名称的函数

 function (){ }

(1) 创建函数

//函数声明
function fn(){
}

(2) 函数表达式

var fun = function(){
    //函数体
}
//变量名称就是函数名称
//调用
fun()

 函数名称() 和 函数名称

函数名称()表示函数的调用,例如 fn() fun()

函数名称就是一个变量,变量中保存了一个函数。

 

函数表达式和函数声明区别

函数声明创建的函数整体会提升,可以先调用再创建。

 函数表达式创建的函数只存在变量的提升,必须先创建再调用。

 

练习:使用函数表达式创建函数,传递任意两个数字,返回两个数字之间所有整数的和 

var getSum=function(a,b){
//计算a~b之间所有整数的和
for(var i=a,sum=0;i<=b;i++){
sum+=i;
}
return sum;
}
console.log( getSum(1,100) );

 

 

匿名函数自调用

全局污染:全局变量的出现所造成的

解决:尽量避免使用全局变量,转为局部变量

(function(a){
    //函数作用域
    //放置每块功能代码
})(2)
( function(user){
    var num=4;
    console.log(user); //root
})( 'root');

 

6. 回调函数

函数名称或者匿名函数实参的形式传递

为了控制指定函数的调用

 

 

 




 

 

 

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值