1、函数声明和函数表达式有什么区别
2、什么是变量的声明前置?什么是函数的声明前置
3、arguments 是什么
4、函数的"重载"怎样实现
5、立即执行函数表达式是什么?有什么作用
6、求n!,用递归来实现
1、
函数声明:function functionName(){} (声明不必放到调用的前面)
函数表达式:函数表达式其实就是创建一个匿名的函数声明并赋值给一个变量。var fn = function(){} (声明必须放到调用的前面)
函数声明会提前,函数表达式可以省略标识符(函数名)。
2、
所谓的变量声明前置就是在一个作用域块中,所有的变量都被放在块的开始出声明。
和变量声明前置一样,执行代码之前会先读取函数声明,只要函数在代码中进行了声明,无论它在哪个位置上进行声明,js引擎都会将它的声明放在范围作用域的顶部。
3、
arguments是一个类数组对象。代表传给一个function的参数列表。
arguments其实是函数的一个内置参数的数组对象,通过arguments[1、2、3]等...我门可以获取到相应的传入参数.
arguments对象是函数内部的本地变量;arguments 已经不再是函数的属性了。可以在函数内部通过使用 arguments 对象来获取函数的所有参数。这个对象为传递给函数的每个参数建立一个条目,条目的索引号从0开始。它包括了函所要调用的参数。object对象。类数组。
简单的连续相加:
function test(){
var test=0;
for(var i=0; i<arguments.length; i++)
{
test= test + arguments[i];
}
return test;
}
console.log(test(1, 4, 5, 7)); // 输出值为 17
4、
在 JS 中没有重载! 同名函数会覆盖。 但可以在函数体针对不同的参数调用执行相应的逻辑
5、
立即执行函数表达式是什么?有什么作用
(function(){
var a = 1;
})()
作用: 隔离作用域。
比如JavaScript中没有命名空间,而且只有function代码块内部可以隔离变量作用域,自调用匿名函数就用来防止变量弥散到全局,以免各种js库冲突。
6、
function multiply(n){
if(n===1){
return 1;
}
return n*multiply(n-1);
}
multiply(3);//6
7、以下代码输出是什么?
function getInfo(name, age, sex){
console.log('name:',name);
console.log('age:', age);
console.log('sex:', sex);
console.log(arguments);
arguments[0] = 'valley';
console.log('name', name);
}
getInfo('饥人谷', 2, '男');
getInfo('小谷', 3);
getInfo('男');
name: 饥人谷
age: 2
sex: 男
["饥人谷", 2, "男"]
name valley
undefined
name: 小谷
age: 3
sex: undefined
["小谷", 3]
name valley
undefined
name: 男
age: undefined
sex: undefined
["男"]
name valley
undefined
8、写一个函数,返回参数的平方和?
function test(){
var test=0;
for(var i=0; i<arguments.length; i++)
{
test= test + arguments[i]*arguments[i];
}
return test;
}
9、如下代码的输出?为什么
console.log(a);
var a = 1;
console.log(b);
console.log(a)输出的是undefined、因为变量在当前作用域下被提升了,结果在console.log(a)前面的var a;虽然声明了但是没有赋值,结果为undefined.
console.log(b)完全是没有声明也没有赋值,结果是报错.//ReferenceError: b is not defined(…)
10、
Uncaught TypeError: sayAge is not a function(…)
答:根据函数声明提升的论据可知,sayNme('world');会返回'hello world'.而sayAge(10);因为是使用表达式的形势定义的所以,当调用在定义之前就会报错,sayAge is not a function.