1.js函数的定义、调用、执行
function fn(){
console.log(123);
}
fn();
注意:以这种方式定义的函数,在调用的时候既可以在函数之前调用,也可以在函数之后调用。
var fn = function(){
console.log(123);
};
fn();
注意:以这种方式定义的函数,在调用的时候只能在函数之后调用。
2.JavaScript代码运行分两个阶段:预解析→执行
预解析:在预解析时,会提前将script标签里所有的函数定义和变量声明提前而变量的赋值不会提前,这样就可以先调用再执行方法一里定义的函数(先调用后定义)。而方法二里的变量也会提前,但是赋值不会提前。(不能先调用后定义) 方法二里定义的函数又叫函数表达式,后面需要加“;”。
执行:按照代码顺序从上到下执行(例外:setTimeout,setInterval,ajax里的回调函数,事件中的函数需要触发执行)
3.js函数的常用方法
var cd = function(){
console.log('test');
};
function fn(callback){
callback();
}
fn(cd);
// 将一个函数作为另一个函数的参数
function fn1(){
var n =1;
var fn = function(){
n ++;
console.log(n);
};
return fn;
}
var fn2 = fn1();
fn2();
fn2();
fn2();
// 结果:123
// 闭包的使用,本应为222,闭包则使得fn里的空间成为私有空间,可以使用fn1里的变量
总结:函数不仅可以作为参数,也可以作为返回值;函数的嵌套形成闭包。
4.关于作用域
var data = [];
for (var i = 0; i < 3; i++) {
data[i] = function(){
console.log(i);
}
}
data[0]();
data[1]();
data[2]();
// 执行结果:3 3 3
注:JavaScript没有块级作用域,JavaScript有两种作用域:全局作用域、函数作用域。(异常处理作用域:try catch、eval作用域)答两种就好,括号里的作用域作为扩展。
var data = [];
for (var i = 0; i < 3; i++) {
data[i] = (function(k){
return function(){
console.log(k);
}
})(i);
}
data[0]();
data[1]();
data[2]();
// 执行结果:0 1 2
注:闭包的作用就是通过最少两层的函数嵌套形成私有作用域,缓存中间值
5.面向对象的写法
function JuiceMachine(fruit){// 构造函数
this.fruit = fruit;
this.produceJuice = function(){
console.log(this.fruit + '果汁');
}
}
JuiceMachine.produceJuice();
// 报错:JuiceMachine.produceJuice is not a function
// this方式加的这些属性都属于通过构造函数生成的对象的,不能通过函数名直接调用;以“.”生成的属性和方法可以直接通过函数名调用
JuiceMachine.brand = '九阳';// brand商标
JuiceMachine.open = function(){
console.log('open');
}
// JuiceMachine.open();
// 函数本身就是一个对象,可以加新的对象、新的行为
var apple = new JuiceMachine("苹果");
apple.produceJuice();
var brand = apple.brand;// 这里的brand没有值,商标和打开的行为是属于果汁机的
var orange = new JuiceMachine("橘子");
orange.produceJuice();
注:function有双重身份→1,对象;2,构造函数;在JavaScript里没有明确的类的区分