來自妙味的一套面試題,如下答案來自JS講師的現場上課記錄!javascript
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
A.對數組裏數據的排序能夠用 sort 函數,若是排序效果非預期,能夠給 sort 函數加一個排序函數的參數;
B.reverse 用於對數組數據的倒序排列;
C.向數組的最後位置加一個新元素,能夠用 pop 方法;
D.unshift 方法用於向數組刪除第一個元素;面試
var a = b = 10; (function(){ var a=b=20 })(); console.log(b);
A.10 B.20 C.報錯 D.undefined數組
var a=[1, 2, 3]; console.log(a.join());
A.123 B.1,2,3 C.1 2 3 D.[1,2,3]app
A.1558 B.1552 C.15553 D.1553ecmascript
var a = 888; ++a; alert(a++);
A.888 B.889 C.890 D.891函數
A.首字符必須是大寫或小寫的字母,下劃線(_)或美圓符($);
B.除首字母的字符能夠是字母,數字,下劃線或美圓符;
C.變量名稱不能是保留字;
D.長度是任意的;
E.區分大小寫;this
A.!(3 <= 1);
B.(4 >= 4) && (5 <= 2);
C.(「a」 == 「a」) && (「c」 != 「d」);
D.(2 < 3) || (3 < 2);code
var i = 0,j = 0; for(; i < 10, j < 6; i++, j++){ k = i + j; }
A.16 B.10 C.6 D.12對象
A.2 B.1 C.3 D.undefined
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';
function fn1() { alert(1); } alert( fn1() );
A.1;
B.alert(1);
C.function fn1() { alert(1); };
D.undefined;
fn1(); var fn1 = function(a){ alert(a); }
A.1 B.程序報錯 C.alert(1); D.undefined
A.-1 B.5 C.程序報錯 D.-10
A.一共有兩個參數,省略第二個參數表示從參數開始位置提、截取到字符串結束;
B.提取以前會比較兩個參數的大小,並根據大小調整位置;
C.能夠接收負數參數,負數表示從後往前數字符位置;
D.若是沒有設置參數,直接返回整個字符串;
A.true B.false
A.arguments 中保存了實際傳入函數內的全部參數;
B.return 只能在函數內部使用;
C.setInterval(fn1, 1000) 只會調用一次 fn1;
D.Date 對象的 getMonth() 獲取到的值比實際月份小 1;
A.parseInt(12.5) == parseFloat(12.5);
B.Number('') == parseFloat('');
C.isNaN('abc') == NaN;
D.typeof NaN === 'number';
A.'==' 在比較過程當中,不但會比較兩邊的值,還會比較兩邊的數據類型;
B.NaN == NaN 的結果是 true;
C.isNaN,判斷傳入的參數是否爲數字,爲數字返回 true,不然返回 false;
D.字符串的 length 只能夠獲取,不能夠設置;
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
var a = 100; function fn1() { alert(a); var a = 10; } alert( fn1() );
A.100;
B.10;
C.function fn1() { alert(1); };
D.undefined;
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]
A.數組的 length 既能夠獲取,也能夠修改;
B.調用 pop() 方法,不會修改原數組中的值;
C.shift() 方法的返回值是新數組的長度;
D.調用 concat() 方法,會修改原數組的值;
var a = 10; function test() { a = 100; alert(a); alert(this.a); var a; alert(a); } test();
A.10 B.100 c.undefined D.程序報錯
var arr=new Array(5); arr[1]=1; arr[5]=2; console.log(arr.length);
A.2 B.5 C.6 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();
A.null == undefined;
B.null === undefined;
C.undefined == false;
D.NaN == NaN;
A.-3.14 B.-3 C.-4 D.3.14
var s="abcdefg"; alert(s.substring(1, 2));
A.a B.b C.bc D.ab
A._125dollor B.1207A C.-dollor D.this
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]; } }
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));
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));
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);
- 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,你們共同交流討論哈~