区别
JavaScript 引擎在加载数据时,对它们是区别对待的。步骤如下。
1.先读取函数声明;
2.在执行上下文中生成函数定义;
以下函数可以正常运行,因为函数声明会在任何代码执行之前先被读取并添加到执行上下文。
console.log(sum(10, 10));//20
function sum(num1, num2) {
return num1 + num2;
}
// 会出错
console.log(sum(10, 10));
let sum = function(num1, num2) {
return num1 + num2;
};
因为这个函数定义包含在一个变量初始化语句中,而不是函数声明中。
//会出错
console.log(sum(10, 10));
var sum = function(num1, num2) {
return num1 + num2;
};
函数作为值
函数名在ECMAScript 中就是变量,所以函数可以用在任何可以使用变量的地方。不仅可以把函数作为参数传给另一个函数,而且还可以在一个函数中返回另一个函数。
function callSomeFunction(someFunction, someArgument) {
return someFunction(someArgument);
}
function add10(num) {
return num + 10;
}
let result1 = callSomeFunction(add10, 10);
console.log(result1); // 20
如果是访问函数而不是调用函数,那就必须不带括号,所以传给callSomeFunction()的必须是add10。
function createComparisonFunction(propertyName) {
return function(object1, object2) {
let value1 = object1[propertyName];
let value2 = object2[propertyName];
if (value1 < value2) {
return -1;
} else if (value1 > value2) {
return 1;
} else {
return 0;
}
};
}
let data = [
{name: "Zachary", age: 28},
{name: "Nicholas", age: 29}
];
data.sort(createComparisonFunction("name"));
console.log(data[0].name); // Nicholas