【IMWeb秋招訓(xùn)練營(yíng)】【筆試篇】

引言

關(guān)于面試和筆試,二者是相輔相成的闸英,但是锯岖,不管是哪一個(gè),都不要好高騖遠(yuǎn)甫何,基礎(chǔ)是最重要的出吹。

  • 找準(zhǔn)定位,重視基礎(chǔ):前端發(fā)展日新月異辙喂,只有基礎(chǔ)打牢捶牢,才能更快的學(xué)習(xí)、適應(yīng)乃至創(chuàng)造新技術(shù)巍耗。根深方能蒂固秋麸。
  • 用更遠(yuǎn)的視角去看面試:先做一個(gè)優(yōu)秀的FE,再考慮能去哪些公司炬太。
  • 面試注重廣度灸蟆,筆試注重深度。筆試亲族,總而言之就是基礎(chǔ)知識(shí)&邏輯思維的綜合考察炒考。


正文

題目1:編寫一個(gè)函數(shù)將列表子元素順序反轉(zhuǎn)

考察點(diǎn)

  • 子元素
  • 性能

解答

  • 方法1:直接的DOM操作
       var ul = document.getElementById('target');
       var liLists = ul.getElementsByTagName('li');
       var len = liLists.length;
       while (len--) {
             ul.appendChild(ul.childNodes[len]);
       }

缺點(diǎn):每次循環(huán)都影響dom生成可缚,損耗性能

  • 方法2: fragment
        var ul = document.getElementById('target');
        var liLists = ul.getElementsByTagName('li');
        var fragment = document.createDocumentFragment();
        for (var i = liLists.length - 1; i >= 0; i--) {
            fragment.appendChild(liLists[i]);
        }
        ul.appendChild(fragment);

優(yōu)點(diǎn):使用到了createDocumentFragment()

  • 方法3:Array reverse
        var ul = document.getElementById('target');
        var children = Array.prototype.slice.call(ul.getElementsByTagName('li'), 0);
        var len = children.length;
        var str = '';

        children.reverse();

        for (var i = 0; i < len; i++) {
            str += children[i].outerHTML;
        }
        ul.innerHTML = str;

優(yōu)點(diǎn):思路加分,同時(shí)性能較高

  • 方法4:innerHTML
        var ul = document.getElementById('target');
        var liLists = ul.getElementsByTagName('li');
        var str = '';
        for (var i = liLists.length - 1; i >= 0; i--) {
            str += '<li>' + liLists[i].innerHTML + '</li>';
        }
        ul.innerHTML = str;

優(yōu)點(diǎn):循環(huán)里不會(huì)影響DOM生成斋枢,效率高

總結(jié)

  • 越簡(jiǎn)單的題帘靡,越能區(qū)分水平
  • 脫離框架,熟練掌握dom操作
  • 出現(xiàn)循環(huán)的地方杏慰,多考慮性能
DOM:查找
getElementsByTagName() // 通過(guò)標(biāo)簽名稱
getElementsByName() // 通過(guò)元素的Name屬性值
getElementById() // 通過(guò)元素Id测柠,唯一性
getElementsByClassName() // 通過(guò)class名稱
DOM :創(chuàng)建
createDocumentFragment() // 創(chuàng)建一個(gè)DOM片段
createElement()  // 創(chuàng)建一個(gè)具體的元素
createTextNode() // 創(chuàng)建一個(gè)文本節(jié)點(diǎn)
DOM :操作
appendChild() // 添加
removeChild() // 移除
replaceChild() // 替換
insertBefore() // 插入
題目2 :畫出ajax模型圖

考察點(diǎn)


解答

總結(jié)

  • 越開(kāi)放的題,可拓展的知識(shí)點(diǎn)越多
  • 形成完整的JS拓?fù)鋱D
  • 注意兼容性問(wèn)題
題目3:寫一個(gè)獲取頁(yè)面url參數(shù)的函數(shù)getQuery(key)缘滥,如url是:https://ke.qq.com?name=kevin&age=18 可輸出getQuery('name')為‘kevin’轰胁,getQuery('age')為18

考察點(diǎn)

  • BOM
  • 字符串處理
  • 正則

解答

  • 方法1:Array split
function getQuery (key) {
    var url = window.location.search;
    var result = [];
    if (url.indexOf('?') != -1) {
        var str = url.substr(1);
        strs = str.split('&');
        for (var i = 0; i < strs.length; i++) {
            var splitArr = strs[i].split('=');
            result[splitArr[0]] = splitArr[1];
        }
    }
    return result[key];
}

缺點(diǎn):數(shù)組操作,不夠優(yōu)雅

  • 方法2:正則
function getQuery (key) {
   var reg = new RegExp("(^|&)" + name + "=[^&]*)(&|$)", "i");
   var r = window.location.search.substr(1).match(reg);
   return r ? r[2] : null;
}

方法1與方法2的遺漏點(diǎn):轉(zhuǎn)義問(wèn)題

  • 方法2:正則(改進(jìn))
function getQuery (key) {
   var reg = new RegExp("(^|&)" + name + "=[^&]*)(&|$)", "i");
   var r = window.location.search.substr(1).match(reg);
   return r ? decodeURIComponent(r[2]) : null;
}

總結(jié)

  • 熟悉BOM
  • 字符串處理朝扼,優(yōu)先嘗試正則
  • 涉及URL赃阀,多注意轉(zhuǎn)義問(wèn)題
題目4:寫一個(gè)Tips提示
  1. 一天之內(nèi),第一次進(jìn)來(lái)時(shí)顯示擎颖,再次訪問(wèn)時(shí)不顯示
    考察點(diǎn)
  • 本地存儲(chǔ)
  • 日期處理
  • localStorage與Cookie
  • localstorage有兼容問(wèn)題榛斯,在IE怎么存儲(chǔ)
  1. 點(diǎn)擊“我知道了”或者“X”后,不再顯示


考察點(diǎn)

  • 事件
  • 兼容性

解答

  • 兼容性代碼
function addEvent (elem, type, fn) {
    if (elem.addEventListener) {
        elem.addEventListener(type, fn, false);
    } else if (elem.attachEvent) {
        elem[type + fn] = function () {
            fn.call(elem);
        };
        elem.attachEvent('on' + type.elem[type + fn]);
    } else {
        elem['on' + type] = fn;
    }
}
  • 事件處理的一種思路:
var $tips = document.getElementById('tips');
var $tipsClose = document.getElementById('tips-close');
$tipsClose.onclick = ...

缺點(diǎn):缺少組件化思想(如果頁(yè)面有多個(gè)tips搂捧,不好復(fù)用)

  • 改進(jìn)
var Util = {
    addEvent: function () {},
    save: function () {
        // cookie處理
    }
}
function Tips () {
    ...
    Util.addEvent(...);
    return this;
}
var tips1 = new Tips({
    onClose: function () {},       // 關(guān)閉回調(diào)
    duration: 24 * 60 * 60 * 1000, // 持續(xù)時(shí)間
    ...
})

總結(jié)

  • 事件的原生封裝
  • 多實(shí)例化驮俗、組件化的思想去實(shí)現(xiàn)

結(jié)尾

  • 基礎(chǔ),是筆試的重中之重允跑;脫離框架王凑,回歸本質(zhì)
  • 有沒(méi)有多種方法?自己的方法是否是最優(yōu)解
  • 邏輯的嚴(yán)密性聋丝,邊緣條件的考慮
  • 注意“筆試”與“機(jī)試”的區(qū)別
  • 除了JavaScript索烹,不要忘了CSS、算法
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末弱睦,一起剝皮案震驚了整個(gè)濱河市百姓,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌况木,老刑警劉巖垒拢,帶你破解...
    沈念sama閱讀 218,204評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異火惊,居然都是意外死亡子库,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門矗晃,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人宴倍,你說(shuō)我怎么就攤上這事张症〔旨迹” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 164,548評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵俗他,是天一觀的道長(zhǎng)脖捻。 經(jīng)常有香客問(wèn)我,道長(zhǎng)兆衅,這世上最難降的妖魔是什么地沮? 我笑而不...
    開(kāi)封第一講書人閱讀 58,657評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮羡亩,結(jié)果婚禮上摩疑,老公的妹妹穿的比我還像新娘。我一直安慰自己畏铆,他們只是感情好雷袋,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,689評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著辞居,像睡著了一般楷怒。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上瓦灶,一...
    開(kāi)封第一講書人閱讀 51,554評(píng)論 1 305
  • 那天鸠删,我揣著相機(jī)與錄音,去河邊找鬼贼陶。 笑死刃泡,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的每界。 我是一名探鬼主播捅僵,決...
    沈念sama閱讀 40,302評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼眨层!你這毒婦竟也來(lái)了庙楚?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,216評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤趴樱,失蹤者是張志新(化名)和其女友劉穎馒闷,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體叁征,經(jīng)...
    沈念sama閱讀 45,661評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡纳账,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,851評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了捺疼。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片疏虫。...
    茶點(diǎn)故事閱讀 39,977評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出卧秘,到底是詐尸還是另有隱情呢袱,我是刑警寧澤,帶...
    沈念sama閱讀 35,697評(píng)論 5 347
  • 正文 年R本政府宣布翅敌,位于F島的核電站羞福,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏蚯涮。R本人自食惡果不足惜治专,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,306評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望遭顶。 院中可真熱鬧张峰,春花似錦、人聲如沸液肌。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,898評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)嗦哆。三九已至谤祖,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間老速,已是汗流浹背粥喜。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,019評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留橘券,地道東北人额湘。 一個(gè)月前我還...
    沈念sama閱讀 48,138評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像旁舰,于是被迫代替她去往敵國(guó)和親锋华。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,927評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 單例模式 適用場(chǎng)景:可能會(huì)在場(chǎng)景中使用到對(duì)象箭窜,但只有一個(gè)實(shí)例毯焕,加載時(shí)并不主動(dòng)創(chuàng)建,需要時(shí)才創(chuàng)建 最常見(jiàn)的單例模式磺樱,...
    Obeing閱讀 2,067評(píng)論 1 10
  • 工廠模式類似于現(xiàn)實(shí)生活中的工廠可以產(chǎn)生大量相似的商品纳猫,去做同樣的事情,實(shí)現(xiàn)同樣的效果;這時(shí)候需要使用工廠模式竹捉。簡(jiǎn)單...
    舟漁行舟閱讀 7,761評(píng)論 2 17
  • 1. tab列表折疊效果 html: 能源系統(tǒng)事業(yè)部 崗位名稱: 工作地點(diǎn) 崗位名...
    lilyping閱讀 1,862評(píng)論 0 1
  • 一芜辕、DOM 什么是DOM?Document Object Model(文檔對(duì)象模型)块差。DOM是針對(duì)HTML和XML...
    空谷悠閱讀 973評(píng)論 0 2
  • 《ijs》速成開(kāi)發(fā)手冊(cè)3.0 官方用戶交流:iApp開(kāi)發(fā)交流(1) 239547050iApp開(kāi)發(fā)交流(2) 10...
    葉染柒丶閱讀 5,147評(píng)論 0 7