1.函數(shù)聲明和函數(shù)表達式有什么區(qū)別
- 函數(shù)聲明會提前,函數(shù)表達式可以省略函數(shù)名
2.什么是變量的聲明前置犁珠?什么是函數(shù)的聲明前置
在解釋器執(zhí)行時弟劲,會將變量和函數(shù)聲明前置,放在作用域的前面
3.arguments 是什么
在函數(shù)內(nèi)部唉地,可以使用argument對象獲取到該函數(shù)的所有傳入?yún)?shù)
4.函數(shù)的"重載"怎樣實現(xiàn)
在函數(shù)體內(nèi)針對不同的參數(shù)調(diào)用執(zhí)行相應的邏輯,就是if判斷
5.立即執(zhí)行函數(shù)表達式是什么传透?有什么作用
···
(function(){
....
})()
···
隔離作用域
6.求n!耘沼,用遞歸來實現(xiàn)
function factor(n)
{
if (n == 1)
{
return 1;
}
return n * factor(n-1);
}
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, '男');
/*
name: 饑人谷
age: 2
sex: 男
["饑人谷", 2, '男']
name valley
*/
getInfo('小谷', 3);
/*
name: 小谷
age: 3
sex: undefined
["小谷", 3]
name valley
*/
getInfo('男');
/*
name: 男
age: undefined
sex: undefined
["男"]
name valley
*/
8.寫一個函數(shù)朱盐,返回參數(shù)的平方和群嗤?
function sumOfSquares()
{
var sum = 0;
for (a in arguments)
{
sum += arguments[a] * arguments[a]
}
return sum;
}
var result = sumOfSquares(2,3,4)
var result2 = sumOfSquares(1,3)
console.log(result) //29
console.log(result2) //10
9.如下代碼的輸出?為什么
console.log(a); //undefined
var a = 1;
console.log(b); //erroe 你是想考1吧_(:зゝ∠)_
10.如下代碼的輸出兵琳?為什么
sayName('world');
sayAge(10);
function sayName(name){
console.log('hello ', name); //hello world
}
var sayAge = function(age){
console.log(age); //erroe 狂秘,調(diào)用在定義前
};
11.如下代碼輸出什么? 寫出作用域鏈查找過程偽代碼
var x = 10
bar()
function foo() {
console.log(x) //10
}
function bar(){
var x = 30
foo()
}
global = {
x: 10
foo() = {
}
bar() = {
x:30
}
}
12.如下代碼輸出什么? 寫出作用域鏈查找過程偽代碼
var x = 10;
bar()
function bar(){
var x = 30;
function foo(){
console.log(x) //30
}
foo();
}
global = {
x: 10
bar() = {
x:30
foo()
}
}
13.以下代碼輸出什么? 寫出作用域鏈的查找過程偽代碼
var x = 10;
bar()
function bar(){
var x = 30;
(function (){
console.log(x) //30
})()
}
global = {
x: 10
bar() = {
x:30
}
}
14.以下代碼輸出什么? 寫出作用域鏈查找過程偽代碼
var a = 1;
function fn(){
console.log(a) //undefined
var a = 5
console.log(a) //5
a++
var a
fn3()
fn2()
console.log(a) //20
function fn2(){
console.log(a) //6
a = 20
}
}
function fn3(){
console.log(a) //1
a = 200
}
fn()
console.log(a) //200
/*
undefined
5
1
6
20
200
*/
global = {
a: 1(200)
fn() = {
a:5(6)(20)
fn2()
}
fn3() = {
}
}