函数
1. 函数的定义
function,是被设计为执行特定任务的代码块
问:为什么需要函数
可以让代码重复使用,提高开发的效率
2. 函数的使用
a.函数声明语法
b.函数命名规范
》和变量命名基本一致
》尽量小驼峰式命名法
》前缀应该为动词
c.函数的调用语法
函数名()
3. 函数传参
使用有参的函数的原因
提高函数的灵活性
a.有参数的函数声明和调用
声明语法
注:参数列表
》传入数据列表
》声明这个函数需要传入几个数据
》多个数据用逗号隔开
调用语法
函数名(传递的参数列表)
b.形参和实参
形参:声明函数时写在函数名右边小括号里的叫形参(形式上的参数)
实参:调用函数时写在函数名右边小括号里的叫实参(实际上的参数)
补充:1.当实参的个数小于形参的个数时,控制台输出的结果是NaN
2.当实参大于形参的个数时,我们再函数(function)内使用arguments,控制台会输出[1 ,2 ,3]数组(如下图)
4.函数返回值
a.使用函数返回值的原因:
》函数执行后得到结果,结果是调用者想要拿到的(一句话,函数内部不需要输出结果,而是返回结果)
》对执行结果的扩展性更高,可以让其他的程序使用这个结果
b.用return返回数据
当函数需要返回数据出去时,用return关键字
语法
return 数据
细节
》在函数体中使用return关键字能将内部的执行结果交给函数外部使用
》函数内部只能出现1次return ,并且return 后面代码不会再被执行,所以return后面的数据不要换行写
》return会立即结束当前函数
》函数可以没有return, 这种情况函数默认返回值为undefined
拓展:函数返回多个值
语法
return [数据1,数据2,…];
return xxx${数据1}xx${数据2}
5. 作用域
a.作用域概述
通常来说,一段程序代码中所用到的名字并不总是有效和可用的,而限定这个名字的可用性的代码范围就是这个名字的作用域。
优点:作用域的使用提高了程序逻辑的局部性,增强了程序的可靠性,减少了名字冲突
作用域的划分:全局作用域,局部作用域,块级作用域
全局作用域(全局有效):作用于所有代码执行的环境(整个script 标签内部)或者一个独立的Js 文件
局部作用域(局部有效):作用于函数内的代码环境,就是局部作用域。因为跟函数有关系,所以也称为函数作用域
块级作用域({}内有效):块作用域由{}包括,if语句和for语句里面的{}等
b.在javascript 中,根据作用域的不同,变量可分为:全局变量,局部变量,块级变量
全局变量(函数外部let变量):全局变量在任何区域都可以访问和修改
局部变量(函数内部let 的变量):局部变量只能在当前函数内部访问和修改
块级变量({}内部的let变量):let定义的变量,只能在块级作用域里访问,不能跨块访问,也不能跨函数访问
c.变量的作用域
特殊情况(注意!!!)
如果函数内部或者块级作用域内部,变量没有声明,直接赋值,也当全局变量看,但是强烈不推荐
但是有一种情况,函数内部的形参可以看做是局部变量
d.变量的访问原则-作用域链
作用域链:根据在内部函数可以访问外部函数变量的这种机制,用链式查找决定哪些数据能被内部函数访问(就近原则)
例:
上图结果为:num=0
6.匿名函数
a.匿名函数
定义:将匿名函数赋值给一个变量,并通过变量名称进行调用,我们将这个称为函数表达式
语法:
let fn=function (){
}
调用:
fn()
b.立即执行函数
作用:避免全局变量之间的污染
语法:
方式一
(function () {
})();
方式二
(function () {
}())
注:
1.这两者作用相同且不需要再调用就执行
2.最前面的**()是放形参,也可不写:后面的()**是放实参
3.多个立即数同时执行时,要使用 ;隔开
补充:(求小时,分钟,秒)