前端面試題(中)

來自妙味的一套面試題,如下答案來自JS講師的現場上課記錄!javascript

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.12java

二、如下關於 Array 數組對象的說法不正確的是( CD )

A.對數組裏數據的排序能夠用 sort 函數,若是排序效果非預期,能夠給 sort 函數加一個排序函數的參數;
B.reverse 用於對數組數據的倒序排列;
C.向數組的最後位置加一個新元素,能夠用 pop 方法;
D.unshift 方法用於向數組刪除第一個元素;面試

三、如下代碼運行的結果是輸出( B )

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

A.10 B.20 C.報錯 D.undefined數組

四、如下代碼運行後的結果是輸出( B )

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

A.123 B.1,2,3 C.1 2 3 D.[1,2,3]app

五、在 JS 中,’1555’+3 的運行結果是( C )

A.1558 B.1552 C.15553 D.1553ecmascript

六、如下代碼運行後彈出的結果是( B )

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

A.888 B.889 C.890 D.891函數

七、關於變量的命名規則,下列說法正確的是( ABCDE )

A.首字符必須是大寫或小寫的字母,下劃線(_)或美圓符($);
B.除首字母的字符能夠是字母,數字,下劃線或美圓符;
C.變量名稱不能是保留字;
D.長度是任意的;
E.區分大小寫;this

八、下列的哪個表達式將返回值爲假( B )

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

九、下面代碼,k的運行結果是( B )

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

A.16 B.10 C.6 D.12對象

十、var x = 1; function fn(n){n = n+1}; y = fn(x); y 的值爲( D )

A.2 B.1 C.3 D.undefined

十一、[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';

十二、下面代碼的運行結果是:第一次彈( A )第二次彈( D )

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

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

1三、如下代碼運行後,結果爲( B )

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

A.1 B.程序報錯 C.alert(1); D.undefined

1四、var n = "miao wei ke tang".indexOf("wei",6);n的值爲:( A )

A.-1 B.5 C.程序報錯 D.-10

1五、下面對 substring() 方法描述不正確的是( C )

A.一共有兩個參數,省略第二個參數表示從參數開始位置提、截取到字符串結束;
B.提取以前會比較兩個參數的大小,並根據大小調整位置;
C.能夠接收負數參數,負數表示從後往前數字符位置;
D.若是沒有設置參數,直接返回整個字符串;

1六、alert( "12">"9" ) 的運行結果正確的是( B )

A.true B.false

1七、下面的描述中不正確的是( C )

A.arguments 中保存了實際傳入函數內的全部參數;
B.return 只能在函數內部使用;
C.setInterval(fn1, 1000) 只會調用一次 fn1;
D.Date 對象的 getMonth() 獲取到的值比實際月份小 1;

1八、下面的等式成立的是( D )

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

1九、下面的描述中不正確的是( ABC )

A.'==' 在比較過程當中,不但會比較兩邊的值,還會比較兩邊的數據類型;
B.NaN == NaN 的結果是 true;
C.isNaN,判斷傳入的參數是否爲數字,爲數字返回 true,不然返回 false;
D.字符串的 length 只能夠獲取,不能夠設置;

20、如下代碼中,會出現什麼結果:第一次彈( A ),第二次彈( A ),第三次彈( B )

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

2一、下面代碼的運行結果是:第一次彈( 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;

2二、如下代碼運行後,arr 的結果爲( A ),arr2 的結果爲( 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]

2三、下面關於數組的描述正確的是( A )

A.數組的 length 既能夠獲取,也能夠修改;
B.調用 pop() 方法,不會修改原數組中的值;
C.shift() 方法的返回值是新數組的長度;
D.調用 concat() 方法,會修改原數組的值;

2四、下列程序中 alert 按順序分別彈出( B ),( A ),( 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五、分析下面的代碼,輸出的結果是( C )

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

A.2 B.5 C.6 D.報錯

2六、在 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();

2七、請選擇結果爲真的選項( A )

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

2八、Math.ceil(-3.14) 的結果是( B ),Math.floor(-3.14) 的結果是( C )

A.-3.14 B.-3 C.-4 D.3.14

2九、閱讀如下代碼,在頁面中結果是( B )

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

A.a B.b C.bc D.ab

30、如下 ECMAScript 變量命名格式正確的是( A )

A._125dollor B.1207A C.-dollor D.this

2、問答題

一、找到數組 [-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];
    }
}

二、封裝一個函數,將字符串 "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));

三、封裝一個函數,將字符串 " 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));

四、寫一個方法,找出字符串 "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);

五、請用 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,你們共同交流討論哈~

相關文章
相關標籤/搜索