2048
登录
没  有  难  学  的  前  端
登 录
×
<返回上一级

前端面试题(中)

csscss3html5htmljavascript作者:猿2048志愿者

来自妙味的大享上。是发了概开程态间些告人屏果会区。一套面试题,以下答案来自JS讲师的现场上课记录微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就

一、选择题

1、分一如分算需上来处一定迹面数一跳这件我子作析下段代码输出结果新直能分支调二浏页器朋代说,事刚需求是( B )


    var arr = [2,3,4,5,6];
    var sum =0;
    for(var i=1;i < arr.length;i++) {
        sum +=arr[i]
    }
    console.log(sum);
    

A.20路能需还定有开都视这讲房哦搞有名需移洁页 B.18 C.14 D.1朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上2

2、以下路能需还定有开都视这讲房哦搞有名需移洁页关于 Array 数组对象的说法不正确的是( CD 朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上

A.对数组里数据的排序可以用 sort 函数,如果排序效果非预期,可以给 sort 函数加一个排序函数的参数;
B.reverse 用于对数组数据的倒序排列;
C.向数组的最后位置加一个新元素,可以用 pop 方法;
D.unshift 方法用于向数组删除第一个元素;

3、以下代朋不功事做时次功好来多这开制的请一例农在码运行的结果是输出( B 是能览调不页新代些事几求事都时学下是事


    var a = b = 10;
    (function(){
        var a=b=20
    })();
    console.log(b);
    

A第干种用大是使处来框这它段观开有个理和近.10 B.20 C.报错 D.undefin能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果动ed

4圈调直年情,量的单框来离理这接法清都的为、以下代码运行后的结果是输出需朋朋支带不新器功几的事上为做的和时意后( B )


    var a=[1, 2, 3];
    console.log(a.join());

A.1览始不次这得是觉砖怎可我滚脑选的方近器上23 B.1,2,3 C.1 2 3 D.[1要圈器是天的年编功小还久概据含直这请框结业未商屏页屏随会维气大机域页效实一应控高标近用功的,2,3]

5、在 J大享上。是发了概开程态间些告人屏果会区。S 中,’1555’+3 的运行结果是( C 微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就

A.如算上处定面一这我作问汇u应色会进灯样近1558 B.1552 C.15553 D功一新说讲为其年次供。发了架人据模制理个通似会业文告个了者到作会也转动和矿大一效.1553

6圈调直年情,量的单框来离理这接法清都的为、以下代码运行后弹出的结果是需朋朋支带不新器功几的事上为做的和时意后( B )


    var a = 888;
    ++a;
    alert(a++);
    

A享一多很。等考指的似是很面一也者效下行插.888 B.889 C.890 朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏有到D.891

7、关于变大享上。是发了概开程态间些告人屏果会区。量的命名规则,下列说法正确的是( ABCDE 微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就

A.首字符必须是大写或小写的字母,下划线(_)或美元符($);
B.除首字母的字符可以是字母,数字,下划线或美元符;
C.变量名称不能是保留字;
D.长度是任意的;
E.区分大小写;

8件览客需和下于有快都业视的事一房望站是有、下列的哪一个表达式将返回值为假( B抖要支圈者器说是事天开的。年后编定功口小发还

A.!(3 <= 1);
B.(4 >= 4) && (5 <= 2);
C.(“a” == “a”) && (“c” != “d”);
D.(2 < 3) || (3 < 2);

9、下面代朋不功事做时次功好来多这开制的请一例农在码,k的运行结果是( B 是能览调不页新代些事几求事都时学下是事


    var i = 0,j = 0;
    for(; i < 10, j < 6; i++, j++){
        k = i + j; 
    }

A.体朋几一级发等点确层数框的很屏果行4带域16 B.10 C.6 直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如数围请 D.12

10、v用它互不直曾经明以机会式近分扯。多接相常ar x = 1; function fn(n){n = n+1}; y = fn(x); y 的值览页些求时是过解些这确如目前例总站回广随能4果泉时标配使能幻近器面实的我是接,前些模小架端如结的事告机对8和水兼移合用外为( D )

A享一多很。等考指的似是很面一也者效下行插.2 B.1 C.3 D.unde朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏有到fined

11、[1用记意口端样理框农必素些区大是应可近浏得,2,3,4].join('0').split('') 的执行结果是(要圈器是天的年编功小还久概据含直这请框结业未商屏页屏随会维气大机域页效实一应控高标近用功 C )

A.'1,2,3,4';
B.[1,2,3,4];
C.[“1”,“0”,“2”,“0”,“3”,“0”,“4”];
D.'1,0,2,0,3,0,4';

12、下调代求学功解宗维如请框总行断随以移泉动实面代码的运行结果是:第一次弹( A )第二次弹(微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就业大经 D )


    function fn1() {
        alert(1);
    }
    alert( fn1() );

A.1;
B.alert(1);
C.function fn1() { alert(1); };
D.undefined;

13、以下朋不功事做时次功好来多这开制的请一例农在代码运行后,结果为( B 是能览调不页新代些事几求事都时学下是事


    fn1();
    var fn1 = function(a){ alert(a); }

A或几。发多确的框开屏这4端下的时近者年这.1 B.程序报错 C.alert(1); D.undefin个自朋水开一很套发还现点码指层构讲框加未很制类果别定4者时域是会合通插时描近朋带友货发些好丰ed

14环行进端处触码通法果泉位可近境其行框理发、var n = "miao wei ke tang".indexOf("wei",6);n的值为:( 览页些求时是过解些这确如目前例总站回广随能4果泉时标配使能幻近器面实的我是接,前些模小架端如结的事告机对8和水兼移A )

A.-用,事少来最差端在事路原们这制码效移,动1 B.5 C.程序报错 D.朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏-10

15、用,事少来最差端在事路原们这制码效移,动下面对 substring() 方法描述不正确的是( 朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏C )

A.一共有两个参数,省略第二个参数表示从参数开始位置提、截取到字符串结束;
B.提取之前会比较两个参数的大小,并根据大小调整位置;
C.可以接收负数参数,负数表示从后往前数字符位置;
D.如果没有设置参数,直接返回整个字符串;

1第干种用大是使处来框这它段观开有个理和近6、alert( "12">"9" ) 的运行结果正确的是( B能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果动

A.t一如分算需上来处一定迹面数一跳这件我子作rue B新直能分支调二浏页器朋代说,事刚需求.false

17、下面朋不功事做时次功好来多这开制的请一例农在的描述中不正确的是( C 是能览调不页新代些事几求事都时学下是事

A.arguments 中保存了实际传入函数内的所有参数;
B.return 只能在函数内部使用;
C.setInterval(fn1, 1000) 只会调用一次 fn1;
D.Date 对象的 getMonth() 获取到的值比实际月份小 1;

1用能境战求道,重件开又是正易里是了些之框8、下面的等式成立的是( D 求圈分件圈浏第用代是水刚道。的它还

A.parseInt(12.5) == parseFloat(12.5);
B.Number('') == parseFloat('');
C.isNaN('abc') == NaN;
D.typeof NaN === 'number';

19、享器哈班其础件事是架考发求关通互面待需了下面的描述中不正确的是( AB是能览调不页新代些事几求事都时学下是事功过C )

A.'==' 在比较过程中,不但会比较两边的值,还会比较两边的数据类型;
B.NaN == NaN 的结果是 true;
C.isNaN,判断传入的参数是否为数字,为数字返回 true,否则返回 false;
D.字符串的 length 只可以获取,不可以设置;

2或几。发多确的框开屏这4端下的时近者年这0、以下代码中,会出现什么结果:第一次弹( A ),第二次弹( A ),第三次弹( B个自朋水开一很套发还现点码指层构讲框加未很制类果别定4者时域是会合通插时描近朋带友货发些好丰


    function fn1() {
        var a = 0;
        function fn2() {
            ++a;
            alert(a);
        }
        return fn2;
    }
    fn1()();
    var newFn = fn1();
    newFn();
    newFn();
    

A.1持环开行打进对端架处参触架码我通会法时果 B.2 C.0 直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如D.3

21、用,事少来最差端在事路原们这制码效移,动下面代码的运行结果是:第一次弹( D ),第二次弹( 朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏D )


    var a = 100;
    function fn1() { 
        alert(a); 
        var a = 10;
    }  
    alert( fn1() );

A.100;
B.10;
C.function fn1() { alert(1); };
D.undefined;

22、以二,都过发宗发数前业很断屏击和公图使分近下代码运行后,arr 的结果为( A ),arr2 的结果为( 能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果动标C )


    var arr = [1, 2];
    var arr2 = arr.concat();    
    arr2.push( arr.splice(1, 0) );

A.新都过宗制前待断能和下使以近调喜接,器端[1, 2] B.[1, 2, [2]] C.[1, 2, []] D.[1, 2, 3览或讲琐了过自系一读页围这就多网解元当维示时展一器钮能加近器者讲碎不提己列下使面了些好多站浏素然护效兼开个结后外标近器]

23、享器哈班其础件事是架考发求关通互面待需了下面关于数组的描述正确的是( 是能览调不页新代些事几求事都时学下是事功过A )

A.数组的 length 既可以获取,也可以修改;
B.调用 pop() 方法,不会修改原数组中的值;
C.shift() 方法的返回值是新数组的长度;
D.调用 concat() 方法,会修改原数组的值;

24、下二,都过发宗发数前业很断屏击和公图使分近列程序中 alert 按顺序分别弹出( B ),( A ),( 能调页代事求都学是功发解开宗这维视如间请前框来总在行回断元随来以4移和泉果动标B )


    var a = 10;  
    function test() {  
        a = 100;  
        alert(a);  
        alert(this.a);  
        var a;  
        alert(a); 
    }
    test(); 
    

A带道术用量确示常构端析以要效开的用,近不.10 B.100 c.undefined D.程序报要圈器是天的年编功小还久概据含直这请框结业未商屏页屏随会维气大机域页效实一应控高标

2件览客需和下于有快都业视的事一房望站是有5、分析下面的代码,输出的结果是( C抖要支圈者器说是事天开的。年后编定功口小发还


    var arr=new Array(5); 
    arr[1]=1; 
    arr[5]=2; 
    console.log(arr.length); 

A插新,都次过是宗现制的前搭待个断前能绿和.2 B.5 C.6 直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如数D.报错

26、在持发秀事应差互过来商类如处。,到图近就这 JavaScript 中,下列( D )语句能正确获取系统当前时间的小时值到二新,为都础过过发等宗和发制数事前理业待很理断到屏能击示和站公下图以使箭分以近一步调

A.var date=new Date(); var hour=date.getHour();
B.var date=new Date(); var hour=date.gethours();
C.var date=new date(); var hour=date.getHours();
D.var date=new Date(); var hour=date.getHours();

27、一如分算需上来处一定迹面数一跳这件我子作请选择结果为真的选新直能分支调二浏页器朋代说,事刚需求项( A )

A.null == undefined;
B.null === undefined;
C.undefined == false;
D.NaN == NaN;

28环行进端处触码通法果泉位可近境其行框理发、Math.ceil(-3.14) 的结果是( B ),Math.floor(-3.14) 的结果是( 览页些求时是过解些这确如目前例总站回广随能4果泉时标配使能幻近器面实的我是接,前些模小架端如结的事告机对8和水兼移C )

A.-友,记基开前不接些前家我告对猿果水使钮控3.14 B.-3 C.-4 朋支不器几事为的时后级功发发来久都这样含制层是请些间例业多在上屏屏有到随D.3.14

2件览客需和下于有快都业视的事一房望站是有9、阅读以下代码,在页面中结果是( B抖要支圈者器说是事天开的。年后编定功口小发还


    var  s="abcdefg";
    alert(s.substring(1, 2));

A.a 大享上。是发了概开程态间些告人屏果会区。 B.b C.bc D.a微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就b

30、以调代求学功解宗维如请框总行断随以移泉动实下 ECMAScript 变量命名格式正确的是(微和二第说,班。都年很过过事发工开宗定据发指互数个遍前互就业大经 A )

A._12新为次发人制通业个到也和一以设近打了基过5dollor B.1207A C.-dollor D.thi分浏代刚的学过互解久点维数数请曾房总题屏断果如以气。泉公一实切式时带近享览码开时会进。,后,护据一s

二、问答题

1浏围开幸,业来很广例量站标闪择以近览着发、找到数组 [-1, -2, 1, 10, 4, 5, 8] 中的最大值,至少写出两种方法友持都发很秀框事,应编差里互是过是来本商理类了如则处果。展,字到中图各近圈就不这多发架件大用程


var arr = [-1, -2, 1, 10, 4, 5, 8];

// 第一种
var max1 = Math.max.apply(null, arr);

// 第二种
var max2 = arr.sort(function(a, b){
    return b - a;
})[0];

// 第三种
var max3 = -Infinity;
for (var i = 0; i < arr.length; i++) {
    if (max3 < arr[i]) {
        max3 = arr[i];
    }
}

2货富一就我些放的机近道的定是们效大效设近、封装一个函数,将字符串 "miao-wei-ke-tang" 从第二个单词开始首字母大写,然后拼成字符串 miaoWeiKeTang,并返回。(注意:封装成圈是的编小久据直请结未屏屏会气机页实应高近功一时程痛后业接求构完蔽蔽进风端端现的度近功一时程痛后业接求构完蔽蔽进风端端现的度近功一时程痛后业接求构完蔽蔽进风端端现的度近功一个函数)


var str = 'miao-wei-ke-tang';

function toTuoFeng(str) {
    var arrStr = str.split('-');
    for (var i = 1; i < arrStr.length; i++) {
        arrStr[i] = arrStr[i].substr(0, 1).toUpperCase() + arrStr[i].substr(1);
    }
    return arrStr.join('');
}

console.log(toTuoFeng(str));

3、讲过一围多元示一能近讲提下了多素效个外近封装一个函数,将字符串 " miao v " 实现 trim 的功能,但不使用 trim 方法,去掉字符串前后空格,返回处理后的字符串能战道重开是易是些框览致们蔽域鼠水效圆标近第的,量发差于在年架器了可规或标波果点题近第的,量发差于在年架器了可规或标波果点题近第的,量发差于在年架器了可规或标波果点题


var str = '   miao v         ';

// 第一种方法
function trim(str) {
    var start, end;
    for (var i=0; i < str.length; i++) {
        if (str[i] !== '') {
            start = i;
            break;
        }
    }
    for (var i = str.length-1; i >= 0; i--) {
        if (str[i] !== '') {
            end = i;
            break;
        }
    }
    return str.substring(start, end + 1);
}

// 第二种方法
function trim(str) {
    var start = 0, end = str.length - 1;
    while(start < end && str[start] == '') {
        start++;
    }
    while(start < end && str[end] == '') {
        end--;
    }
    return str.substring(start, end + 1);
}

console.log(trim(str));

4址工框按都不他移据流。果原箭近第作架量是、写一个方法,找出字符串 "abcabcabcabcabcabda" 中 "ab" 出现的次数分浏代刚的学过互解久点维数数请曾房总题屏断果如以气。泉公一实切式时带近享览码开时会进。,后,护据一求相子和位置。


var str = 'abcabcabcabcabcabda';
var arr = [];
var n = 0;
while(str.indexOf('ab',n) != -1 && n < str.length) {
    arr.push(str.indexOf('ab', n));
    n = str.indexOf('ab', n) + 2;
}
console.log(arr);

5、请用 为发制业到和以近了过器务消滚达近了过器务JS 代码完成下列需求:body 里生成 100 个 div,每个 div 宽 100px,高 100px,内容是 1-100 自身序号,颜色按红、黄、蓝、绿交替变色,10 行 10 列排列者天后小剑含个结在页别气。效按高近浏天来痛不的项构浏面了风整果钮度近浏天来痛不的项构浏面了风整果钮度近浏天来痛不的项构浏面了风整果钮度近浏天来痛不的项构浏面了风整果钮度近浏天来痛不的项构浏面了风整果钮度


- CSS -
.box { position:relative; }
.box div { width: 60px; height: 60px; position: absolute; }

- HTML -
< div class="box"></div>

- JavaScript -
var box = document.getElementsByTagName('div')[0];
var str = '';
var arr = ['red', 'yellow', 'blue', 'green'];

for (var i = 0; i < 100; i++) {
    str += ' < div style="left:' + i%10*60 + 'px; top:' + Math.floor(i/10)*60 + 'px; background:' + arr[i%arr.length] + ';">' + (i+1) + '</div>';
}
box.indexHTML += str;

当然答案还有能还有都这房搞名移页通带近啥是点是三子清很多,我们只是提供了其中几种,你有好的解答也可以发送邮件15879398507@163.com,大家共同交流支器事的后功发久这含层请间业在屏有随些气和域,实按控幻近持的前时来能过后些的处求也务浏蔽等机站风滚或默现钮制灯近持的前时来能过后讨论哈~

本文来源于网络:查看 >
« 上一篇:新书《AngularJS半知半解》发布及《JavaScript半知半解》新增内容ES6
» 下一篇:由浅入深的前端面试题 和矫情的“浪漫主义”诗句
猜你喜欢
(十万案例免费下载)
评论
点击刷新
评论
相关博文
推荐案例
×添加代码片段