題目1: 下面的代碼輸出多少?修改代碼讓 fnArri 輸出 i。使用 兩種以上的方法
var fnArr = [];
for (var i = 0; i < 10; i ++) {
fnArr[i] = function(){
return i;
};
}
console.log( fnArr[3]() ); //
輸出10
修改為1
var fnArr = []; for (var i = 0; i < 10; i ++) { (function(i) { fnArr[i] = function(){ return i; };})(i); } console.log( fnArr[3]() );
修改為2
var fnArr = []; for (var i = 0; i < 10; i ++) { fnArr[i] =(function(i){ return (function(){return i;}) ;})(i); } console.log( fnArr[3]() );
題目2: 封裝一個汽車對象,可以通過如下方式獲取汽車狀態
var Car = (function(){ var speed = 0; function setSpeed(s){ speed = s; } function getSpeed(){ return speed; } function accelerate(){ speed=speed+10; } function decelerate(){ speed= speed-10; } function getStatus(){ if(speed>0) return 'running'; else return 'stop'; } return { setSpeed: setSpeed, getSpeed: getSpeed, accelerate:accelerate, decelerate:decelerate, getStatus:getStatus, }; })();
`
題目3:下面這段代碼輸出結果是? 為什么?
var a = 1; setTimeout(function(){ a = 2; console.log(a); }, 0); var a ; console.log(a); a = 3; console.log(a);
輸出1 3 2
setTimeout 會在其他程序執行完再執行
題目4:下面這段代碼輸出結果是? 為什么?
var flag = true; setTimeout(function(){ flag = false; },0) while(flag){} console.log(flag);
因為setTimeout再程序最后執行,故while中的flag一直為true會執行死循環
題目5: 下面這段代碼輸出?如何輸出delayer: 0, delayer:1...(使用閉包來實現)
for(var i=0;i<5;i++){ setTimeout(function(){ console.log('delayer:' + i ); }, 0); console.log(i); }
輸出
0 1 2 3 4 "delayer:5" "delayer:5" "delayer:5" "delayer:5" "delayer:5"
閉包方法
for(var i=0;i<5;i++){ (function(i){ setTimeout(function(){ console.log('delayer:' + i ); }, 0);})(i); console.log(i); }
·題目6: 如何獲取元素的真實寬高
element.offsetWidth
element.offsetHeight
題目7: URL 如何編碼解碼?為什么要編碼?
JavaScript提供四個URL的編碼/解碼方法。
decodeURI()
decodeURIComponent()
encodeURI()
encodeURIComponent()
區別
encodeURI方法不會對下列字符編碼
ASCII字母
數字
~!@#$&()=:/,;?+'
encodeURIComponent方法不會對下列字符編碼
ASCII字母
數字
~!()'
所以encodeURIComponent比encodeURI編碼的范圍更大。
encodeURI被用作對一個完整的URI進行編碼,而encodeURIComponent被用作對URI的一個組件進行編碼。
對于Url來說,之所以要進行編碼,是因為Url中有些字符會引起歧義。
例如,Url參數字符串中使用key=value鍵值對這樣的形式來傳參,鍵值對之間以&符號分隔,如/s?q=abc&ie=utf-8。如果你的value字符串中包含了=或者&,那么勢必會造成接收Url的服務器解析錯誤,因此必須將引起歧義的&和=符號進行轉義,也就是對其進行編碼。
Url的編碼格式采用的是ASCII碼,而不是Unicode,這也就是說你不能在Url中包含任何非ASCII字符,例如中文。否則如果客戶端瀏覽器和服務端瀏覽器支持的字符集不同的情況下,中文可能會造成問題。
題目8: 補全如下函數,判斷用戶的瀏覽器類型
function isAndroid(){ var reg=/Android/gi; return reg.test(window.navigator.userAgent) } funcnction isIphone(){ var reg=/Iphone/gi; return reg.test(window.navigator.userAgent) } function isIpad(){ var reg=/Ipad/gi; return reg.test(window.navigator.userAgent) } function isIOS(){ var reg=/Iphone|Ipad/gi; return reg.test(window.navigator.userAgent) }