一.函數(shù)聲明和函數(shù)表達(dá)式有什么區(qū)別
1.函數(shù)聲明必須有標(biāo)識(shí)符
2.函數(shù)聲明會(huì)提前
3.ECMAScript規(guī)范中表示,函數(shù)聲明語(yǔ)句可以出現(xiàn)在全局代碼中错览,或者內(nèi)嵌在其他函數(shù)中泣矛,但是不能出現(xiàn)在循環(huán)、條件判、或者try/finally以及with語(yǔ)句中邑退。
4.可以創(chuàng)建一個(gè)函數(shù)表達(dá)式即刻執(zhí)行劳澄。
二.什么是變量的聲明前置地技?什么是函數(shù)的聲明前置
網(wǎng)頁(yè)在渲染js的時(shí)候,會(huì)首先渲染變量聲明和函數(shù)聲明秒拔。
例如var a = 1莫矗;var a聲明在當(dāng)前的執(zhí)行上下文會(huì)被前置先渲染,然后再執(zhí)行執(zhí)行a=1砂缩;
函數(shù)聲明也一樣作谚,例如function fn(){ console.log(1) },fn()函數(shù)的聲明會(huì)被前置庵芭。
三.arguments 是什么
arguments是函數(shù)傳參妹懒,通過(guò)arguments[1、2双吆、3]等...我門可以獲取到相應(yīng)的傳入?yún)?shù).
四.函數(shù)的"重載"怎樣實(shí)現(xiàn)?
通過(guò)對(duì)函數(shù)里面定義多個(gè)函數(shù)來(lái)實(shí)現(xiàn)眨唬,使用if語(yǔ)句,不同的參數(shù)對(duì)應(yīng)不同的函數(shù)
五.立即執(zhí)行函數(shù)表達(dá)式是什么好乐?有什么作用?
是指在定義了函數(shù)之后立即執(zhí)行的函數(shù)匾竿,不需要調(diào)用。例:曹宴!function(){}()
作用:可以不用為函數(shù)命名搂橙,污染全局變量
可以形成獨(dú)立的作用域
六.求n!歉提,用遞歸來(lái)實(shí)現(xiàn)
function fn(n){
if(n===1){ return 1 }
return n*fn(n-1)
}
七.以下代碼輸出什么笛坦?
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;
2.getInfo('小谷', 3);
輸出name:小谷废离;age:3;sex:undefined礁芦;['小谷', 3]蜻韭;name: valley
3.getInfo('男');
輸出name:男;age:underfine柿扣;sex:undefined肖方;[“男”];name: valley
八.寫(xiě)一個(gè)函數(shù)未状,返回參數(shù)的平方和俯画?
function fn(){
var result
for(var i=0;i<arguments.length;i++){
result=result+arguments[i]*arguments[i]
}
return result
}
九.如下代碼的輸出?為什么?
console.log(a); undefined 因?yàn)樽兞刻嵘静荩瑅ar a已經(jīng)聲明艰垂,但沒(méi)賦值,所以輸出undefined
var a = 1;
console.log(b); b沒(méi)有聲明也沒(méi)賦值埋虹,所以結(jié)果是報(bào)錯(cuò)
十.如下代碼的輸出猜憎?為什么?
sayName('world');
sayAge(10);
function sayName(name){
console.log('hello ', name);
}
var sayAge = function(age){
console.log(age);
};
輸出分別是hello world和報(bào)錯(cuò)
因?yàn)楹瘮?shù)聲明會(huì)提升,而函數(shù)表達(dá)式不會(huì)搔课,所以當(dāng)渲染到sayName('world'); 時(shí)可以調(diào)用函數(shù)sayName胰柑,但是函數(shù)表達(dá)式不會(huì)提升,所以sayAge(10);不能調(diào)用下面的sayage函數(shù)所以是報(bào)錯(cuò)
十一.輸出如下代碼爬泥,寫(xiě)出作用域鏈查找過(guò)程偽代碼
var x = 10
bar()
function foo() {
console.log(x)
}
function bar(){
var x = 30
foo()
}
輸出結(jié)果為10
執(zhí)行bar(),然后執(zhí)行foo(),bar()里面的x由于作用域不能給foo()使用旦事,所以foo()里面的x的值還是10
十二.如下代碼輸出什么? 寫(xiě)出作用域鏈查找過(guò)程偽代碼
var x = 10;
bar()
function bar(){
var x = 30;
function foo(){
console.log(x)
}
foo();
}
輸出結(jié)果為30
1.先降10賦給x
2.執(zhí)行bar();
3.foo()函數(shù)聲明,30賦給了x
4.執(zhí)行foo();
5.輸出x 為30;
十三.以下代碼輸出什么? 寫(xiě)出作用域鏈的查找過(guò)程偽代碼
var x = 10;
bar()
function bar(){
var x = 30;
(function (){
console.log(x)
})()
}
輸出結(jié)果為30
1.先將10賦值給x
2.執(zhí)行bar()
3.30賦值給x
4.立即執(zhí)行函數(shù)function(){console.log(x)}
5.里面沒(méi)有x從上一級(jí)找急灭,為30
十四.以下代碼輸出什么姐浮? 寫(xiě)出作用域鏈查找過(guò)程偽代碼
var a = 1;
function fn(){
console.log(a)
var a = 5
console.log(a)
a++
var a
fn3()
fn2()
console.log(a)
function fn2(){
console.log(a)
a = 20
}
}
function fn3(){
console.log(a)
a = 200
}
fn()
console.log(a)
輸出結(jié)果為undefined 5 1 6 20 200