類(lèi)型系統(tǒng)
1舍哄、以下表達(dá)式返回的值是多少褪秀?
“1”-null+true
答案: 2
2塌西、type([])的結(jié)果是?
- A “Object”
- B “Function”
- C “Array”
- D “object”
答案: D
3关翎、以下表達(dá)式返回的結(jié)果是false的有?
- A (function(){}).constructor == Object
- B [].constructor == Array
- C true.constructor == Boolean
- D (1).constructor == Number
答案: A (Function)
4饥侵、以下語(yǔ)句執(zhí)行后痊银,a的值不是undefined的有?
- A var a = (function(b){return b;})();
- B var a = document.getElementById('notExistElement');
- C var o = {x:1};var a = o.y;
- D var a
答案: B (null)
知識(shí)點(diǎn)
undefined 出現(xiàn)場(chǎng)景:
已聲明未賦值的變量
獲取對(duì)象不存在的屬性
無(wú)返回值的函數(shù)的執(zhí)行結(jié)果
函數(shù)的參數(shù)沒(méi)有傳入
void(express)
5航邢、實(shí)現(xiàn)type函數(shù)用于識(shí)別標(biāo)準(zhǔn)類(lèi)型和內(nèi)置對(duì)象類(lèi)型耕赘,語(yǔ)法如下:
答案:
function type(obj){
return Object.prototype.toString.call(obj).slice(8, -1).toLowerCase()
}
內(nèi)置對(duì)象
1、以下代碼執(zhí)行完成后president.name的值是
function setName(obj){
obj.name = "obama";
obj = {name:"clinton"};
}
var president = {name:"bush"};
setName(president);
- A."clinton"
- B.undefined
- C."obama"
- D."bush"
答案:C
2膳殷、以下代碼執(zhí)行后a操骡、b的值分別是?
var str = "welcome to NetEase!welcome to MOOC!";
var a = str.indexOf("to");
var b = str.indexOf("to", a+1);
答案:8赚窃,27
3册招、以下代碼執(zhí)行后ret和arr的值分別是?
var arr=[1,2,"a","b"];
var ret=arr.splice(1,2,3);
答案:
ret : [2,"a"]
arr : [1,3,"b"]
知識(shí)點(diǎn)
splice() 方法 向/從數(shù)組中添加/刪除項(xiàng)目考榨,然后返回被刪除的項(xiàng)目跨细。
注釋?zhuān)涸摲椒〞?huì)改變?cè)紨?shù)組。
語(yǔ)法:arrayObject.splice(index,howmany,item1,.....,itemX)
4河质、以下表達(dá)式返回結(jié)果是冀惭?
parseInt("10.1",16)
- A.16
- B.10
- C.10.1
- D.8
答案: A
5、表達(dá)式 "1+1".replace("1","2") 返回結(jié)果是掀鹅?
答案:2+1
知識(shí)點(diǎn)
replace(str1,str2)方法替換的只是第一個(gè)匹配的字符串
如果想要替換全部散休,可以使用正則。(但這種正則表達(dá)式是有局限的)
var str = "男的女的老的少的";
alert(str.replace(new RegExp(/(的)/g),''));
匹配的是一些特定的字符串乐尊,如何匹配動(dòng)態(tài)的字符串呢戚丸?
var replaceStr = "的";
alert(str.replace(new RegExp(replaceStr,'gm'),''));
這樣我們就完成了匹配字符串的動(dòng)態(tài)賦值。
另外還有其他的方法實(shí)現(xiàn)全部替換
alert(str.split(replaceStr).join(''));
6、(/^abc/i).test("Abc123")的結(jié)果是限府?
答案:true
7夺颤、var obj = Object.create({a:1}); obj.hasOwnProperty('a')返回結(jié)果是___?
答案:false ( - a是對(duì)象原型連上的屬性)
知識(shí)點(diǎn)
Object.create(proto[,propertisObject])
是基于原型對(duì)象創(chuàng)建新對(duì)象
Object.prototype.hasOwnproperty判斷一個(gè)屬性是否是對(duì)象自身屬性
表達(dá)式與運(yùn)算符
1胁勺、代碼執(zhí)行后a,b的值分別是多少世澜?
var a = 0
var b = true || a++
答案: 0,true
2署穗、代碼執(zhí)行后a,b的值分別是多少寥裂?
var a = 0
var b = true && a++
答案: 1,0
3案疲、一些表達(dá)式返回結(jié)果為true的有:封恰?
- A Number("a") == NaN
- B false =="0"
- C "123" == 123
- D new String("123") =="123"
答案: BCD
知識(shí)點(diǎn)補(bǔ)充
類(lèi)型轉(zhuǎn)換例外情況:
null == undefined //true
null或undefined參與進(jìn)行==運(yùn)算時(shí)不進(jìn)行隱式類(lèi)型轉(zhuǎn)換
0 == null //false
null == false //false
"undefined" == undefined //false
變量作用域
1、以下代碼執(zhí)行時(shí)兩個(gè)alert的值是多少褐啡?
(function(){
a = 5;
alert(window.a)
var a = 10;
alert(a)
})()
答案:undefined 10
2诺舔、以下代碼執(zhí)行時(shí)alert的值是多少?
var a = 6;
(function(){
alert(window.a)
alert(a)
var a = 10;
alert(a)
})()
答案:6 undefined 10
3春贸、以下代碼執(zhí)行時(shí)兩個(gè)alert的值是多少混萝?
var a = 6;
(function(){
alert(a)
})()
答案:6
4、以下代碼執(zhí)行時(shí)alert的值是多少萍恕?
var x = 10;
function foo(){
alert(x);
}
function bar(){
var x = 20;
foo();
}
bar();
答案:10
知識(shí)點(diǎn)1
用詞法環(huán)境進(jìn)行分析
知識(shí)點(diǎn)2
JS使用動(dòng)態(tài)作用域
JS沒(méi)有塊級(jí)作用域
JS函數(shù)運(yùn)行在他們被定義的作用域里
catch語(yǔ)句可以臨時(shí)改變js變量作用域
閉包
1、以下代碼執(zhí)行時(shí)alert的值是多少车要?
var a=1;
var func = (function(){
var a=2;
return function(){
a++;
alert(a)
}
})()
func();
func();
答案:3,4
面向?qū)ο?/h1>
1允粤、eval函數(shù)中的this值是?
答案:調(diào)用上下文的this
2翼岁、下列關(guān)于js描述正確的有类垫?
- A js中可以使用prototype實(shí)現(xiàn)原型繼承
- B 在對(duì)象構(gòu)造器中,可以使用this創(chuàng)建對(duì)象的屬性
- C js中不能使用面向?qū)ο?/li>
- D js中不能給未定義的變量賦值
答案:AB
3琅坡、使用 new Function()創(chuàng)建的函數(shù)代碼中this是全局對(duì)象悉患?
- A js中可以使用prototype實(shí)現(xiàn)原型繼承
- B 在對(duì)象構(gòu)造器中,可以使用this創(chuàng)建對(duì)象的屬性
- C js中不能使用面向?qū)ο?/li>
- D js中不能給未定義的變量賦值
答案:AB
4榆俺、使用new Function()創(chuàng)建的函數(shù)代碼中的this是全局對(duì)象售躁?
- A 錯(cuò)誤
- B 正確
答案:B
例如:
var foo3 = new Function('var temp = 100; console.log(this); this.temp = 200; return temp + this.temp;');
//this 指window對(duì)象
4、JS中所有函數(shù)都可以當(dāng)成構(gòu)造器茴晋?
- A 錯(cuò)誤
- B 正確
答案:A
5陪捷、以下代碼用于判斷user對(duì)象就有自身屬性name?
user.______('name')
答案:hasOwnProperty
5诺擅、以下代碼alert的值依次是市袖?
function Teacher(){}
Teacher.prototype = {
job : 'teacher',
setName : function(name){
this.name = name
}
}
var bill = new Teacher()
bill.setName('Bill')
alert(bill.name) //Bill
alert(bill.job) //teacher
bill.job = 'assistant';
alert(bill.job) //assistant
delete bill.job;
alert(bill.job); //teacher
答案:Bill teacher assistant teacher
6、寫(xiě)代碼
if( typeof Object.create != 'function'){
Object.create = function(obj){
if( typeof obj != 'object' ){
throw TypeError('Object prototype may only be an Object or null')
}
var r = function(){}
r.prototype = obj
return new r; //new r() 與new r 沒(méi)有區(qū)別烁涌,只是r函數(shù)沒(méi)有參數(shù)時(shí)苍碟,括號(hào)可以省略
}
}
var a = Object.create({x:1,y:2})
alert(a.x)
綜合
1酒觅、寫(xiě)代碼
答案:
function myType(param){
alert("I am an " + Object.prototype.toString.call(param).slice(8, -1) )
}
2、寫(xiě)代碼
function search(arr,dst){
var type = Object.prototype.toString.call(arr).slice(8,-1);
if(type != 'Array'){
throw TypeError('Object prototype may only be an Array')
}
var len = arr.length;
if( !len){
return -1;
}
var l = 0;
var h = len - 1;
while(l <= h){
var m = Math.floor( (h+l)/2 );
if( arr[m] == dst ){
return m;
}else if( dst < arr[m] ){ //左半部分
h = m - 1;
}else{ //右半部分
l = m + 1;
}
}
}
var arr = [1,2,4,6,7,9,19,20,30,40,45,47];
alert( search(arr,45) )