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)文章
js判斷移動(dòng)端橫豎屏視口檢測(cè)實(shí)現(xiàn)的幾種方法
最近做歌一個(gè)小項(xiàng)目,但是要放到我們的app上,然而需要橫豎屏使用不同的樣式,本文就來(lái)介紹一下js判斷移動(dòng)端橫豎屏視口檢測(cè)實(shí)現(xiàn)的幾種方法,感興趣的可以了解一下2021-07-07
package.json與package-lock.json的區(qū)別及詳細(xì)解釋
不知道大家平時(shí)在開(kāi)發(fā)中有沒(méi)有注意到,你的項(xiàng)目中有兩個(gè)文件:package.json,package-lock.json,應(yīng)該很多人平時(shí)都不會(huì)去關(guān)注這兩個(gè)文件有啥關(guān)系吧,這篇文章主要給大家介紹了關(guān)于package.json與package-lock.json的區(qū)別及詳細(xì)解釋,需要的朋友可以參考下2022-08-08
javascript實(shí)現(xiàn)動(dòng)態(tài)改變層大小的方法
這篇文章主要介紹了javascript實(shí)現(xiàn)動(dòng)態(tài)改變層大小的方法,涉及javascript操作頁(yè)面屬性的相關(guān)技巧,需要的朋友可以參考下2015-05-05
javascript的trim,ltrim,rtrim自定義函數(shù)
今天用到j(luò)avascript去掉一個(gè)文本框中字符串兩端的空格,開(kāi)始還以為有trim,ltrim,rtrim函數(shù)(asp中有這三個(gè)函數(shù),弄混了),結(jié)果找半天,沒(méi)有找到。最后找到用正則實(shí)現(xiàn)這樣功能的自定義函數(shù)。2008-09-09
ajax如何實(shí)現(xiàn)頁(yè)面局部跳轉(zhuǎn)與結(jié)果返回
AJAX即“Asynchronous Javascript And XML”(異步JavaScript和XML),是指一種創(chuàng)建交互式網(wǎng)頁(yè)應(yīng)用的網(wǎng)頁(yè)開(kāi)發(fā)技術(shù),通過(guò)在后臺(tái)與服務(wù)器進(jìn)行少量數(shù)據(jù)交換,AJAX 可以使網(wǎng)頁(yè)實(shí)現(xiàn)異步更新,本篇文章給大家介紹ajax如何實(shí)現(xiàn)頁(yè)面局部跳轉(zhuǎn)與結(jié)果返回,感興趣的朋友一起來(lái)學(xué)習(xí)2015-08-08

