目录
-
函数(function)
-
函数是一个对象
-
使用typeof检查函数对象时,会返回function
-
创建函数
-
函数声明提前:
-
使用函数声明形式创建的函数function函数,它会在所有的代码执行之前创建,所以我们可以在函数编写前就调用函数
-
使用函数表达式创建的函数,不会被声明提前,所以不能在声明前调用
-
-
通过函数声明的方式来创建函数
-
-
// 通过函数声明的方式来创建函数,常用
function 函数名([形参1,形参2,……,形参n]){
语句……
}
-
通过函数表达式的方式来创建一个函数
var 函数名 = function([形参1,形参2,……,形参n]){
语句……
};
-
通过构造函数的方式创建
var 函数名 = new Function("语句……");
-
例子:
// 方式1
function fun1(){
console.log('fun1:Hello World!');
}
fun1();
// 方式2
var fun2 = function(){
console.log('fun2:Hello World!');
}
fun2();
// 方式3
var fun3 = new Function("console.log('fun3:Hello World!');");
fun3();
-
参数
-
形参
-
在函数()内指定一个或多个形参(形式参数),多个形参之间用逗号隔开
-
声明形参相当于在函数内部声明了对应的变量,但是并不会赋值
-
-
实参
-
在调用函数时,可以在()内指定实参(实际参数)
-
实参会赋值给函数在对应的形参
-
实参可以是任意数据类型
-
-
注意
-
调用函数时,解析器不会检查实参的数据类型,所以有可能接收到非法实参,如果有可能出错则需要对参数进行类型检查
-
如果实参数量少于形参的数量,则没有后面缺少的实参将是undefined
-
-
-
返回值
-
可以使用return来设置需要返回的值,可以返回任意类型的值
-
// 语法
return 值;
-
如果return后不跟返回值,则会返回undefined;如果没有return语句,也会返回undefined
-
return会结束整个函数
-
立即执行函数
-
函数定义完,立即执行
-
往往只会执行一次
-
// 立即执行函数
( function(形参...){
语句...
})(实参...);
(function(){
console.log('fun4:Hello World!');
})();
-
方法(method)
-
对象的属性值可以是任意数据类型,也可以是函数
-
如果一个函数作为一个对象的属性保存,那么我们称这个函数为这个对象的方法,调用函数就调用对象的方法
-
-
for...in...遍历
-
语法
-
for(var 变量 in 对象){
循环体...
}
-
for...in... 语句,对象中有几个属性,循环体就会执行几次,每次执行都会把对象的一个属性的名字赋值给变量
-
作用域
-
作用域是指一个变量起作用的范围
-
JS中有两种作用域:全局作用域、函数作用域
-
全局作用域:
-
直接写在script标签中的js代码,都是在全局作用域
-
全局作用域在页面打开时创建,在页面关闭时销毁
-
在全局作用域中有一个全局对象window,它代表的是一个浏览器的窗口,它由浏览器创建,我们直接使用
-
在全局作用域中
-
创建的变量都会作为window对象的属性保存
-
创建的函数都会作为window对象的方法保存
-
-
全局作用域中的变量都是全局变量,在页面的任意的位置都可以访问到
-
-
函数作用域:
-
调用函数时创建函数作用域,函数执行完毕函数作用域销毁
-
每调一次会创建一个,互相独立
-
在函数作用域中可以访问到全局作用域的变量;在全局作用域中无法访问到函数作用域的变量
-
当在函数作用域操作一个变量时,它会在自身作用域中寻找,有则用,没有则向上一级寻找。直到找到全局作用域中,如果还没有找到则报错:ReferenceError
-
在函数中要访问全局变量可以使用window对象
-
-
-