一arguments对象
* arguments----->可以获取函数调用的时候,传入的实参的个数
* arguments是一个对象,是一个伪数组
* arguments.length--->是实参的个数
* arguments[索引]---->实参的值
function f1() {
//arguments----->数组使用------伪数组---
var sum=0;
for(var i=0;i<arguments.length;i++){
sum+=arguments[i];
}
return sum;
}
console.log(f1(10,20,30));
二匿名函数
* 命名函数:函数如果有名字,就是命名函数
*
* 匿名函数:函数如果没有名字,就是匿名函数
* 函数表达式:
* 把一个函数给一个变量,此时形成了函数表达式
* var 变量=匿名函数;
* 例子:
* var f1=function (){
*
* };
* 如果是函数表达式,那么此时前面的变量中存储的就是一个函数,而这个变量就相当于是一个函数,就可以直接加小括号调用了
* f1();
*
* 注意:
* 函数表达式后面,赋值结束后,要加分号
函数的自调用,没有名字,调用---声明的同时,直接调用
例:
//函数声明
function f1() {
console.log("");
}
f1();
function f1() {
console.log("");
}
f1();
//函数表达式
var f2 = function () {
console.log("");
};
f2();
f2 = function () {
console.log("");
};
f2();
//函数自调用
(function () {
console.log("");
})();
(function () {
console.log("")
})();
-----------------------------------------------------------------------------------------------
函数也是一种数据类型
function f1() {
console.log("我是函数");
}
//如何获取某个变量的类型? typeof
console.log(typeof f1);
//函数是有数据类型,数据类型:是function 类型的
--------------------------------------------------------------------------------------------------
函数作为参数使用
//函数可以作为参数使用,如果一个函数作为参数,那么我们说这个参数(函数)可以叫回调函数
//只要是看到一个函数作为参数使用了,那就是回调函数
function sayHi(fn) {
console.log("您好");
fn();//fn此时应该是存储一个函数代码
}
function suSay() {
console.log("您好2");
}
sayHi(suSay);
------------------------------------------------------------------------------
//结论:函数是可以作为返回值使用的:
function f1() {
console.log("f1函数调用了");
return function () {
console.log("这是一个函数");
};
}
var ff=f1();//调用
//ff就是一个函数了
ff();
-------------------------------------------------------------------------
js作用域
* 全局变量:声明的变量是使用var声明的,那么这个变量就是全局变量,全局变量可以在页面的任何位置使用
* 除了函数以外,其他的任何位置定义的变量都是全局变量
* 局部变量:在函数内部定义的变量,是局部变量,外面不能使用
* 全局变量,如果页面不关闭,那么就不会释放,就会占空间,消耗内存
*
* 全局作用域:全局变量的使用范围
* 局部作用域:局部变量的使用范围
*
* 块级作用域:一对大括号就可以看成是一块,在这块区域中定义的变量,只能在这个区域中使用,但是在js中在这个块级作用域中定义的变量,外面也能使用;
* 说明:js没有块级作用域,只有函数除外
*
* 隐式全局变量:声明的变量没有var,就叫隐式全局变量
// function f1() {
// number=1000;//是隐式全局变量
// }
// f1();
// console.log(number);
* 全局变量是不能被删除的,隐式全局变量是可以被删除的
* 定义变量使用var是不会被删除的,没有var是可以删除的
// var num1=10;
// num2=20;
// delete num1;//把num1删除了
// delete num2;//把num2删除了
// console.log(typeof num1);
// console.log(num1+10);
// console.log(typeof num2);
---------------------------------------------------------------------------------
预解析:js代码的执行是由浏览器中的JavaScript解析器来执行的。分为两个过程:预解析过程和代码执行过程
* 预解析做什么事?
* 1把变量的声明提前到当前所在的作用域的最上面,只会提升声明,不会提升赋值
*2 函数的声明提前到当前所在的作用域的最上面,只会提升声明,不会提升调用。
3先提升var,再提升function
注意:
//预解析中,变量的提升,只会在当前的作用域中提升,提前到当前的作用域的最上面
//函数中的变量只会提前到函数的作用域中的最前面,不会出去
//预解析会分段(多对的script标签中函数重名,预解析的时候不会冲突)