1.引用類型有哪些护桦?非引用類型有哪些2.如下代碼輸出什么术唬?為什么?
var obj1 = {a:1, b:2}; var obj2 = {a:1, b:2}; console.log(obj1 == obj2); console.log(obj1 = obj2); console.log(obj1 == obj2);
引用類型:對(duì)象沙绝、數(shù)組、函數(shù)、正則钧栖;
基本類型:字符串嘿悬、數(shù)值实柠、布爾值、underfind善涨、null;
輸出:
false //obj1和obj2指向的地址不相同 {a:1,b:2} //obj2指向的地址賦值給obj1窒盐,obj1和obj2共用一個(gè)地址 true // 指向的地址相同
2.如下代碼輸出什么? 為什么?
var a = 1 var b = 2 var c = { name: '饑人谷', age: 2 } var d = [a, b, c]
var aa = a var bb = b var cc = c var dd = d
a = 11 b = 22 c.name = 'hello' d[2]['age'] = 3
console.log(aa) // 1 即便后面a又重新賦值成11但是number做為基本數(shù)據(jù)類型,其賦值后钢拧,只是相當(dāng)于拷貝了一個(gè)值的副本并重新創(chuàng)建了一個(gè)棧內(nèi)存空間 console.log(bb) // 2 console.log(cc) // {name: "hello", age: 3} cc和c都有同樣的一個(gè)對(duì)象指針或地址蟹漓,即兩者尋址最終都會(huì)到達(dá)同樣一個(gè)堆內(nèi)存中 console.log(dd) //[1, 2, {name: "hello", age: 3}] 通過(guò)數(shù)組索引改變了原對(duì)象c中的age屬性
3.如下代碼輸出什么? 為什么?
var a = 1 var c = { name: 'jirengu', age: 2 }
function f1(n){ ++n } function f2(obj){ ++obj.age }
f1(a) f2(c) f1(c.age) console.log(a) //輸出1,f1中相當(dāng)于是聲明了一個(gè)n=a源内,是把a(bǔ)的值賦給了n葡粒,++n變化的n的值,a不會(huì)發(fā)生變化膜钓。 console.log(c) //輸出{name: "jirengu", age: 3}嗽交,f2()中相當(dāng)于obj=c。把c指向的地址賦值給了obj颂斜,所以++obj.age后夫壁,指向的地址內(nèi)的值發(fā)生了變化,再打印c的時(shí)候打印的是指向的地址內(nèi)的值沃疮,所以age變成3
4.過(guò)濾如下數(shù)組盒让,只保留正數(shù)梅肤,直接在原數(shù)組上操作
var arr = [3,1,0,-1,-3,2,-5] function filter(arr){ for(var i=0;i<arr.length;i++){ if(arr[i]<=0){ arr.splice(i,1); filter(arr); } } } filter(arr) console.log(arr) // [3,1,2]
5.過(guò)濾如下數(shù)組,只保留正數(shù)邑茄,原數(shù)組不變凭语,生成新數(shù)組
var arr = [3,1,0,-1,-3,2,-5]; var arr2 = arr.slice(); function filter(arr2) { for(var i=0;i<arr2.length;i++) { if(arr2[i]<=0) { arr2.splice(i,1); filter(arr2); } } } filter(arr2); console.log(arr2) // [3,1,2] console.log(arr) // [3,1,0,-1,-2,2,-5];
var arr = [3,1,0,-1,-3,2,-5]; var arr2 = arr.filter(function(elem){ return (elem > 0); }); console.log(arr2) // [3,1,2] console.log(arr) // [3,1,0,-1,-2,2,-5];
6.寫一個(gè)深拷貝函數(shù),用兩種方式實(shí)現(xiàn).
var obj1 = { name: 'xiaoming', age: 16, xxx: { name: 'xiaohua', age: 15 } } //第一種 function deepcopy(obj){ var newobj = {}; for(var key in obj){ if( typeof(obj[key]) === 'object'){ newobj[key] = deepcopy(obj[key]) }else{ newobj[key] = obj[key] } } return newobj; } var obj2 = deepcopy(obj1) console.log(obj2) obj1.xxx.name="hello"; console.log(obj1) console.log(obj2); //第二種 function deepcopy(obj){ var newobj = JSON.parse(JSON.stringify(obj)); return newobj; } var obj2 = deepcopy(obj1); console.log(obj2); obj1.xxx.name="hello"; console.log(obj1); console.log(obj2);