JS常見(jiàn)面試試題總結(jié)【去重、遍歷、閉包、繼承等】
本文實(shí)例講述了JS常見(jiàn)面試試題。分享給大家供大家參考,具體如下:
JavaScript面試題總結(jié)
1,首先是數(shù)組去重算法:給一個(gè)數(shù)組,去掉重復(fù)值
(function() { var arr = [1, 2, 3, 3, 4, ]; function unique() { var result = []; var tem = {}; for (var i = 0; i < arr.length; i++) { if (!tem[arr[i]]) { result.push(arr[i]); tem[arr[i]] = 1; } } return result; } })();
2,多維數(shù)組,至少3層的遍歷,將數(shù)組整合一維數(shù)組,網(wǎng)上給出的方案
//遍歷多維數(shù)組 var arr = [1, 2, 3, [4, [5, [6]]]]; // arr.length Array.prototype.each = function(fn) { try { //1 目的: 遍歷數(shù)組的每一項(xiàng) //計(jì)數(shù)器 記錄當(dāng)前遍歷的元素位置 this.i || (this.i = 0); //var i = 0 ; //2 嚴(yán)謹(jǐn)?shù)呐袛嗍裁磿r(shí)候去走each核心方法 // 當(dāng)數(shù)組的長(zhǎng)度大于0的時(shí)候 && 傳遞的參數(shù)必須為函數(shù) if (this.length > 0 && fn.constructor == Function) { // 循環(huán)遍歷數(shù)組的每一項(xiàng) while (this.i < this.length) { //while循環(huán)的范圍 //獲取數(shù)組的每一項(xiàng) var e = this[this.i]; //如果當(dāng)前元素獲取到了 并且當(dāng)前元素是一個(gè)數(shù)組 if (e && e.constructor == Array) { // 直接做遞歸操作 e.each(fn); } else { //如果不是數(shù)組 (那就是一個(gè)單個(gè)元素) // 這的目的就是為了把數(shù)組的當(dāng)前元素傳遞給fn函數(shù) 并讓函數(shù)執(zhí)行 //fn.apply(e,[e]); fn.call(e, e); } this.i++; } this.i = null; // 釋放內(nèi)存 垃圾回收機(jī)制回收變量 } } catch (ex) { // do something } return this; }
3,獲得url查詢參數(shù)方案
1)一個(gè)是用正則表達(dá)式方法
//獲取url參數(shù) function GetQueryString(name) { var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)"); //js match返回的是一數(shù)組 var r = location.search.substr(1).match(reg); if (r != null) { return r[2]; } else { return null; } }
2)另外一種就是利用split結(jié)合數(shù)組遍歷實(shí)現(xiàn),這個(gè)比較容易實(shí)現(xiàn)就不貼代碼了
4,正則表達(dá)式去掉空格
/**去掉字符串前后所有空格*/ function trim(str){ return str.replace(/(^\s*)|(\s*$)/g, ""); }
5,閉包的概念考察
6,原型繼承如何實(shí)現(xiàn),原型繼承有兩種方案
1)第一種是利用prototype
var obj={name:'seven'}; var a=function(){}; a.prototype=obj; var aa=new a(); alert(aa.name);
2)第二種是利用apply或者call
function people(name,age){ //屬性 this.name=name; this.age=age; //方法 this.show=function(){ console.log("my name is"+this.name+" and I am "+this.age+" years old"); }; } function student(name,age,school){ people.apply(this,arguments); this.school=school; this.showYourself=function(){ console.log("my name is"+this.name+" and I am "+this.age+" years old"+" my school is"+ this.school); }; } var tom=new student('tom','19','xtu'); tom.showYourself();
7,ES6常用知識(shí)點(diǎn)考察
感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。
更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript數(shù)組操作技巧總結(jié)》、《JavaScript排序算法總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》及《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
JavaScript6 let 新語(yǔ)法優(yōu)勢(shì)介紹
這篇文章主要介紹了JavaScript6 let 新語(yǔ)法優(yōu)勢(shì)介紹的相關(guān)資料,需要的朋友可以參考下2016-07-07ajax實(shí)現(xiàn)加載頁(yè)面、刪除、查看詳細(xì)信息 bootstrap美化頁(yè)面!
這篇文章主要為大家詳細(xì)介紹了ajax實(shí)現(xiàn)加載頁(yè)面、刪除、查看詳細(xì)信息,利用bootstrap美化頁(yè)面,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03基于JS實(shí)現(xiàn)回到頁(yè)面頂部的五種寫(xiě)法(從實(shí)現(xiàn)到增強(qiáng))
這篇文章主要介紹了基于JS實(shí)現(xiàn)回到頁(yè)面頂部的五種寫(xiě)法(從實(shí)現(xiàn)到增強(qiáng))的相關(guān)資料,本文介紹的非常詳細(xì),實(shí)用性也非常高,非常具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09js知識(shí)點(diǎn)總結(jié)之getComputedStyle的用法
getComputedStyle是一個(gè)可以獲取當(dāng)前元素所有最終使用的CSS屬性值,下面這篇文章主要給大家介紹了關(guān)于js知識(shí)點(diǎn)總結(jié)之getComputedStyle用法的相關(guān)資料,需要的朋友可以參考下2022-10-10javascript結(jié)合html5 canvas實(shí)現(xiàn)(可調(diào)畫(huà)筆顏色/粗細(xì)/橡皮)的涂鴉板
js+html5 canvas實(shí)現(xiàn)的涂鴉畫(huà)板特效,可調(diào)畫(huà)筆顏色|粗細(xì)|橡皮,可以保存涂鴉效果為圖片編碼,測(cè)試了下還不錯(cuò),感興趣的朋友可以參考下2013-04-04