1.引用類型有哪些挽唉?非引用類型有哪些
引用類型:Object / Array / Function / Date / RegExp / Error / Map / Set …
非引用類型即基本類型:Undefined / Null / Boolean / Number / String
區(qū)別:
基本類型:是存儲在棧中的簡單數(shù)據(jù)段苏潜,也就是說,它們的值直接存儲在變量訪問的位置吱涉。
引用類型:存儲在堆中的對象,也就是說,存儲在變量處的值是一個指針女揭,指向存儲對象的內(nèi)存處。
2.如下代碼輸出什么栏饮?為什么
var obj1 = {a:1, b:2};
var obj2 = {a:1, b:2};
console.log(obj1 == obj2);//輸出false,obj1和obj2都是引用類型吧兔,兩者儲存的地址并不相同
console.log(obj1 = obj2);//此處將obj2賦值給obj1,此時二者儲存的地址變一樣了
console.log(obj1 == obj2);//二者儲存的地址一樣袍嬉,所以為真
3.如下代碼輸出什么? 為什么
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境蔼,基本類型,aa和a有不同的椝磐ǎ空間
console.log(bb) //2箍土,同上
console.log(cc)//{name: "hello", age: 3};cc和c儲存的地址相同罐监,指向堆內(nèi)存的同一對象
console.log(dd)//[1,2,{name:'hello',age:3}]吴藻;dd和d指向同一個堆內(nèi)存的對象,d[2]則指向堆內(nèi)存中的c
4.如下代碼輸出什么? 為什么
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) //c.age為基本類型
console.log(a) //輸出1弓柱,f1(a)默認(rèn)執(zhí)行var n=a即把a(bǔ)賦值給n沟堡,這里n和a有不同的棧內(nèi)存侧但,++n不改變a的值。
console.log(c)//輸出{name:'jirengu',age:3}航罗,當(dāng)調(diào)用f2(c)時禀横,即執(zhí)行var obj=c,因為c屬于引用類型粥血,所以obj和c指向堆內(nèi)存的同一個對象```
5.過濾如下數(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);
i--;
}
}
}
filter(arr);
console.log(arr); // [3,1,2]
6.過濾如下數(shù)組立莉,只保留正數(shù)绢彤,原數(shù)組不變,生成新數(shù)組
var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
var newArr = [];
for(var i = 0; i<arr.length;i++){
if(arr[i]>0){
newArr.push(arr[i]);
}
}
return newArr;
}
var arr1 = filter(arr);
console.log(arr1);
console.log(arr);
7.寫一個深拷貝函數(shù)蜓耻,用兩種方式實現(xiàn).
拷貝引用和拷貝實例茫舶,就是我們說的淺拷貝和深拷貝。
拷貝原對象的引用刹淌,即是最簡單的淺拷貝饶氏。
深拷貝也就是拷貝出一個新的實例,新的實例和之前的實例互不影響有勾。
方法一:
function deepCopy(obj) {
var newObj = {};
for(var key in obj) {
if(typeof obj[key] == 'number' || typeof obj[key] == 'string' || typeof obj[key] == 'boolean' || typeof obj[key] === 'undefined' || obj[key] === null) {
newObj[key] = obj[key];
} else {
newObj[key] = deepCopy(obj[key]);
}
}
return newObj;
}
方法二:JOSN對象中的stringify可以把一個js對象序列化為一個JSON字符串疹启,parse可以把JSON字符串反序列化為一個js對象,能夠處理JSON格式能表示的所有數(shù)據(jù)類型蔼卡,但是對于正則表達(dá)式類型喊崖、函數(shù)類型等無法進(jìn)行深復(fù)制(而且會直接丟失相應(yīng)的值),同時如果對象中存在循環(huán)引用的情況也無法正確處理
var newObj = JSON.parse(JSON.stringify(obj));