進階任務十一

題目1: 下面的代碼輸出多少慌盯?修改代碼讓 fnArri 輸出 i恋技。使用 兩種以上的方法

 var fnArr = [];
    for (var i = 0; i < 10; i ++) {
        fnArr[i] =  function(){
            return i;
        };
    }
    console.log( fnArr[3]() );  // 輸出結果為:10
var fnArr = []

    for (var i = 0; i < 10; i ++) {
        !function(j){
            fnArr[j] =  function(){
                return j;
            };
        }(i)
        
    }
    console.log( fnArr[3]() );//3

    //方法二
    var fnArr = [];
    for (var i = 0; i < 10; i ++) {
      fnArr[i] =  function(i){ 
        return function(){
          return i; 
        };
      }(i);  
    }
    console.log( fnArr[3]() ); // 3

題目2: 封裝一個汽車對象砂沛,可以通過如下方式獲取汽車狀態(tài)

var Car = (function(){
       var speed = 0;
       function setSpeed(s){
           speed = s
           if( speed === s) {
            return 1
           }else {
            return -1
           }
       }
       function getSpeed() {
            return speed;
       }
       function accelerate() {
            speed += 10;
       }
       function decelerate() {
            if(speed === 0) {
                return;
            }
            speed -= 10;
       }
       function getStatus() {
        if(speed === 0) {
            return 'stop'
        }else {
            return 'running'
        }
       }
       
       return {
          setSpeed: setSpeed,
          getSpeed: getSpeed,
          accelerate: accelerate,
          decelerate: decelerate,
          getStatus: getStatus
       }
})()
console.log(Car.setSpeed(30));
console.log(Car.getSpeed()); //30
Car.accelerate();
Car.getSpeed(); //40;
Car.decelerate();
Car.decelerate();
Car.getSpeed(); //20
Car.getStatus(); // 'running';
Car.decelerate(); 
Car.decelerate();
Car.getStatus();  //'stop';
console.log(Car.setSpeed);

題目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
雖然設置的時間為0秒瞎暑,但是它必須等待本次執(zhí)行的代碼執(zhí)行完畢后才會執(zhí)行

題目4:下面這段代碼輸出結果是? 為什么?

var flag = true;
setTimeout(function(){
    flag = false;
},0)
while(flag){}
console.log(flag);
//flag 值一直為 true献烦,無限循環(huán) while(flag){}滓窍,不會執(zhí)行 console.log(flag);

題目5: 下面這段代碼輸出?如何輸出delayer: 0, delayer:1...(使用閉包來實現(xiàn))

for(var i=0;i<5;i++){
    setTimeout(function(){
         console.log('delayer:' + i );
    }, 0);
    console.log(i);
}
for(var i=0;i<5;i++){
        setTimeout((function(i){
            return function(){
                console.log('delayer:' + i );
            }
        })(i), 0);
        console.log(i);
    }

    //方法二
    for (var i = 0; i < 5; i++) {
        !function (i) {
            setTimeout(function () {
                console.log('delayer:' + i);
            }, 0);
        }(i)
    }

題目6: 如何獲取元素的真實寬高

var element = document.querySelector('ul')
var width = window.getComputedStyle(element).width;
var height = window.getComputedStyle(element).height;

題目7: URL 如何編碼解碼仿荆?為什么要編碼贰您?

  • 可以使用 encodeURI() 或者 encodeURIComponent()
  • 可以使用 decodeURI() 或者 decodeURIComponent()

原因:

  • url的編碼格式采用的是ASCII碼坏平,而中文不是ASCII的字符,如果不先編碼就傳輸數(shù)據(jù)锦亦,那么可能會出現(xiàn)問題舶替。所以通過把中文字符編碼為符合ASCII標準的字符,就可以避免這個問題

  • url字符串中使用 key=value 鍵值對的方式傳輸參數(shù)杠园,鍵值對之間用 & 隔開顾瞪。服務端接收到參數(shù)后,會根據(jù) & 分割鍵值對抛蚁,根據(jù) = 分割鍵和值陈醒。如果這時候鍵或值中含有 & 、= 這些字符瞧甩,那么服務端分割參數(shù)的時候會出現(xiàn)錯誤钉跷。所以通過把鍵值中的 &、= 進行編碼肚逸,就可以避免這個問題

題目8: 補全如下函數(shù)爷辙,判斷用戶的瀏覽器類型

    function isAndroid(){
        return /Android/i.test(navigator.userAgent);
    }
    function isIphone(){
        return /iPhone/i.test(navigator.userAgent);
    }
    function isIpad(){
        return /iPad/i.test(navigator.userAgent);
    }
    function isIOS(){
        return /(iPad) | (iPhone)/i.test(navigator.userAgent);
    }
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市朦促,隨后出現(xiàn)的幾起案子膝晾,更是在濱河造成了極大的恐慌,老刑警劉巖务冕,帶你破解...
    沈念sama閱讀 222,183評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件血当,死亡現(xiàn)場離奇詭異,居然都是意外死亡禀忆,警方通過查閱死者的電腦和手機臊旭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來油湖,“玉大人巍扛,你說我怎么就攤上這事领跛》Φ拢” “怎么了?”我有些...
    開封第一講書人閱讀 168,766評論 0 361
  • 文/不壞的土叔 我叫張陵吠昭,是天一觀的道長喊括。 經(jīng)常有香客問我,道長矢棚,這世上最難降的妖魔是什么郑什? 我笑而不...
    開封第一講書人閱讀 59,854評論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮蒲肋,結果婚禮上蘑拯,老公的妹妹穿的比我還像新娘钝满。我一直安慰自己,他們只是感情好申窘,可當我...
    茶點故事閱讀 68,871評論 6 398
  • 文/花漫 我一把揭開白布弯蚜。 她就那樣靜靜地躺著,像睡著了一般剃法。 火紅的嫁衣襯著肌膚如雪碎捺。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,457評論 1 311
  • 那天贷洲,我揣著相機與錄音收厨,去河邊找鬼。 笑死优构,一個胖子當著我的面吹牛诵叁,可吹牛的內容都是我干的。 我是一名探鬼主播钦椭,決...
    沈念sama閱讀 40,999評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼黎休,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了玉凯?” 一聲冷哼從身側響起势腮,我...
    開封第一講書人閱讀 39,914評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎漫仆,沒想到半個月后捎拯,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,465評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡盲厌,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,543評論 3 342
  • 正文 我和宋清朗相戀三年署照,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片吗浩。...
    茶點故事閱讀 40,675評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡建芙,死狀恐怖,靈堂內的尸體忽然破棺而出懂扼,到底是詐尸還是另有隱情禁荸,我是刑警寧澤,帶...
    沈念sama閱讀 36,354評論 5 351
  • 正文 年R本政府宣布阀湿,位于F島的核電站赶熟,受9級特大地震影響,放射性物質發(fā)生泄漏陷嘴。R本人自食惡果不足惜映砖,卻給世界環(huán)境...
    茶點故事閱讀 42,029評論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望灾挨。 院中可真熱鬧邑退,春花似錦竹宋、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至乓土,卻和暖如春宪潮,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背趣苏。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評論 1 274
  • 我被黑心中介騙來泰國打工狡相, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人食磕。 一個月前我還...
    沈念sama閱讀 49,091評論 3 378
  • 正文 我出身青樓尽棕,卻偏偏與公主長得像,于是被迫代替她去往敵國和親彬伦。 傳聞我的和親對象是個殘疾皇子滔悉,可洞房花燭夜當晚...
    茶點故事閱讀 45,685評論 2 360

推薦閱讀更多精彩內容

  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現(xiàn)单绑,斷路器回官,智...
    卡卡羅2017閱讀 134,707評論 18 139
  • 以書作伴 2010-11-16 15:00 閱讀(?)評論(8) 自從認識了字,就喜歡讀書搂橙。記得剛識了幾個字歉提,就拿...
    零星往事閱讀 524評論 0 0
  • 今天看一篇文章,是日本岐阜大學教授安東俊六寫的《論杜甫的夔州詩》譯者李寅生区转,文章里提及杜甫詩“紀德名...
    水仙書生閱讀 1,520評論 5 4
  • 春天慢慢過去時魏割,夏季的風漸漸散開。在春天結束愛情正勒,在夏天蜻韭,會遇見什么呢悼尾? 五月,悶而熱的天氣湘捎,天空中的云即使壓的再...
    燈火如初閱讀 333評論 1 2