JS函数上

239 阅读5分钟

学习目标:

节数知识点要求
第一节 函数的初识什么是函数了解
第二节 函数的分类系统函数了解
自定义函数了解
函数的使用了解了解
第三节 函数的类型函数类型掌握
第四节 函数的作用域和作用域链函数作用域掌握

思考:为什么使用函数?使用函数能解决什么问题?

您能够对代码进行复用:只要定义一次代码,就可以多次使用它。

您能够多次向同一函数传递不同的参数,以产生不同的结果。

一、什么是函数

函数:是一般是由事件驱动的,为了实现特定功能的,可以重复调用一段可以执行的代码块

二、函数的分类

2.1 系统函数

字符串,数学函数,数组函数等,js系统给我们提供好的函数。

2.2 自定义函数

自己定义的函数:函数的声明

function(形式参数1,形式参数2...){

语句。

}

2.3 函数的使用

2.3.1函数调用

2.3.2函数和事件绑定

三、函数的类型

3.1无参无返回值类型函数(函数声明)

3.2.无参有返回值类型函数

3.3 return的使用

1.return,从字面意思来看就是返回,官方定义return语句将终止当前函数并返回当前函数的值,return后面的语句不执行。

2. 官方定义return后面可以跟一个value,也就是说可以跟javascript中的任何数据类型,数字,字符串,对象等,当然也可是再返回一个函数

3.3.3 return 返回函数

总之:return false 只在当前函数有效,不会影响其他外部函数的执行。(也就是其中断的只是一个函数,对于其外部函数没影响)

3.3.4 return 注意事项

retrun true; 返回正确的处理结果。

return false;返回错误的处理结果,终止处理。

]

return;把控制权返回给页面。

function myFunction(a) { var power = 10; return a * power; }

function myFunction(a) { var power = 10; return a * power; }

返回 undefined

function foo1() {

return {

​ bar:'hello'

}

}

function foo2() {

return

{

​ bar:'hello'

}

}

//第一个返回一个对象

//第二个返回undefine 因为第二个 return 后面没内容,分号自动加载 return 后面

3.4 void的使用

javascript:void(0) 该操作符指定要计算一个表达式但是不返回值。

void()仅仅是代表不返回任何值,但是括号内的表达式还是要运行void(alert("running!"))

href="#"与href="javascript:void(0)"的区别

# 包含了一个位置信息,默认的锚是#top 也就是网页的上端。

而javascript:void(0), 仅仅表示一个死链接。

3.7 匿名函数(函数声明)

匿名函数:在JavaScript中,当把函数当做数据使用时,可以不设置名字

函数必须要先声明后使用

函数声明的提升:

如果函数先使用了,后声明,函数自动提升到使用之前。

3.8 回调函数(learn,study)

什么是回调函数?

当一个函数作为另一个函数的参数时,作为参数的函数被称之为回调函数。

3.10.1 Function与function的区别

Function是一个功能完整的对象,作为JS的内置对象之一。而function只是一个关键字,用来创建一个普通函数或对象的构造函数。JS的普通函数都是Function对象的实例,所以函数本身也是一个对象,就像var一样,只不过这个对象具有可调用特征而已

3.11递归函数

递归函数:函数自己调用自己

3.12 默认值和函数参数

Es6的参数默认值

Es5的参数默认值

参数是一个函数

3.12.1 高阶函数

高阶函数

高阶函数英文叫Higher-order function。那么什么是高阶函数?

JavaScript的函数其实都指向某个变量。既然变量可以指向函数,函数的参数能接收变量,那么一个函数就可以接收另一个函数作为参数,这种函数就称之为高阶函数。

四、函数的作用域和作用域链

4.1 什么是作用域

作用域(scope)就是变量和函数的可访问范围,或者说变量或函数起作用的区域

4.2 作用域分类

Javascript只有两种作用域

4.2.1全局作用域

全局作用域:变量和函数在整个程序中一直存在,所有地方都可以读取。

全局变量(global variable):在函数外部声明的变量,它可以在函数内部读取。

那么什么情况下声明为全局变量呢,多个函数共同使用。

4.2.2局部作用域

局部作用域:变量和函数只在函数内部存在。在函数外部变量失效。

和作用域与之对应的,javascript中有两种变量:

局部变量(local variable):在函数内部定义的变量,外部无法读取。

在函数中,参数也是局部变量

函数也有作用域,声明在外部的函数,可以任意位置调用,声明在函数内部的函数,一般只能在内部调用。

局部变量会在函数运行以后被删除。

全局变量会在页面关闭后被删除。

4.2.3 变量加var和不加var的区别

1.在函数作用域内 加var定义的变量是局部变量,不加var定义的就成了"全局变量"

2.在全局作用域下,使用var定义的变量不可以delete,没有var定义的变量可以delete.也就说明隐式全局变量严格来说不是真正的变量,而是全局对象(window)的属性,因为属性可以通过delete删除,而变量不可以

3.使用var定义的变量不赋值时会有一个默认初始值:undefined,而不使用var定义的变量在alert()时浏览器会给出错误信息:a is not defined

4.在ECMASceipt5的'use strict'模式下,如果变量没有使用var定义,会报错

4.2.4 实例:计数器的累加