Arguments对象
变量的作用域
/* javascript中的变量作用域: * 全局变量:全局域+函数域. * 局部变量:当前函数域. */var a = "a";function fn(){ var b = "b"; alert(a); //output a alert(b); //output b}fn();alert(a); //output aalert(b); //未输出
/* 在javascript定义变量可以不使用"var". 在定义局部变量时,没有使用"var": * javascript会自动将没有var的局部变量,定义为全局变量 需要注意的是: * 依旧不建议大家这样编写代码. */var a = "a";function fn(){ b = "b"; alert(a); //output a alert(b); //output b}fn();alert(a); //output aalert(b); //output b
/* 解读代码: * 定义一个全局变量a,并初始化为a. * 定义一个函数fn(),但该函数没有被调用(函数中的代码是不执行的) * 该函数中,定义了局部变量a,但没有初始化. * 调用函数fn(),执行该函数中的代码. * 第一次打印变量a,打印的是局部变量a. * 第二次打印变量a,打印的是局部变量a. javascript的特点: * javascript一次性定义代码中所有变量. * 全局变量与局部变量同名时,在函数域中:只能访问局部变量. */var a = "a";function fn(){ alert(a); //output undefined var a = "b"; alert(a); //output b}fn();alert(a); //output a
特殊函数
/* 匿名函数:没有名的函数 * 定义函数的一种方式:var 函数名 = function(){} * 将匿名函数作为参数,传递给另一个函数. * 将匿名函数用来完成一次性任务. 回调函数: * 将一个函数作为参数传递给另一个函数,而作为参数的函数,就叫做回调函数. * 将一个匿名函数作为参数传递给另一个函数,而作为参数的匿名函数,就叫做匿名回调函数. */var one = function(){ return 1;}var two = function(){ return 2;}// 形参a, b是一个函数.function fn(a, b){ return a() + b();}alert(fn(one, two)); //output 3// 将以上代码进行改写alert(fn(function(){ return 1;}, function(){ return 2;})); //output 3
/* 什么是一次性:只能使用一次的. * 一次性函数: * 用来完成页面初始化工作的函数(不严格) * 定义即调用的函数(不严格) * 语法规定只能使用一次的. * 自调函数: * 第一个小括号:封装函数 * 第二个小括号:调用函数 */( function(){ alert("this is javascript."); })();( function(str){ alert(str + "this is javascript."); })("hello ");
/* 内部(私有)函数: * 与Java中的内部类很相似. * 好处:保证了私有性. * 与局部变量的作用是一样的. */function fn(){ var a = "a"; function n(){ var b = "b"; alert(a); alert(b); } n();}fn();//a b
/* (了解)返回函数的函数(内部函数的一种特殊用法) * 定义一个函数,可以执行两个逻辑体 */function fn(){ var a = "a"; return function(){ return a; }} alert(fn()); //output function(){return a;}alert(fn()()); //output a
预定义函数