JavaScript引用類型與對(duì)象拷貝

1.引用類型有哪些檀训?非引用類型有哪些

  • 非引用類型:number刻蚯、string互墓、boolean恕刘、undefined缤谎、null
  • 引用類型:object,對(duì)象又可以分成三個(gè)子類型:
    • 狹義的對(duì)象(object)
    • 數(shù)組(array)
    • 函數(shù)(function)

2.如下代碼輸出什么?為什么

var obj1 = {a:1, b:2};
var obj2 = {a:1, b:2};
console.log(obj1 == obj2);
// false,它們的屬性值雖然相同褐着,但是在內(nèi)存中的地址不同
console.log(obj1 = obj2);
// 返回obj2所指向的對(duì)象坷澡,賦值語(yǔ)句會(huì)復(fù)制對(duì)象的地址
console.log(obj1 == obj2);
// true,經(jīng)過(guò)賦值后它們指向同一個(gè)對(duì)象

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含蓉,因?yàn)榛绢愋褪侵祩鬟f频敛,a賦值給aa的時(shí)候值為1,以后a的值改變并不會(huì)影響aa
console.log(bb)
// 2馅扣, 同上 
console.log(cc)
// {name: 'hello', age: 3},對(duì)象賦值是復(fù)制地址斟赚,而所有指向該地址的變量操作和訪問(wèn)的都是同一個(gè)對(duì)象。
console.log(dd)
// [1,2,{name: 'hello', age: 3}],在數(shù)組中引用變量相當(dāng)于為數(shù)組中對(duì)應(yīng)位置的元素使用賦值語(yǔ)句差油,其它理由同上拗军。

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) 
console.log(a) 
// 1,執(zhí)行f1(a)傳遞參數(shù)相當(dāng)于在函數(shù)內(nèi)部執(zhí)行:var n = a;
而a只是將1賦值給n蓄喇,改變n的值并不會(huì)改變a
console.log(c)
// {name:'jirengu',age: 3}, 執(zhí)行f2(c)時(shí):var obj =c;
而c是對(duì)象发侵,會(huì)進(jìn)行地址傳遞,操作obj會(huì)影響a的值妆偏;
執(zhí)行f1(c.age)因?yàn)閏.age是基本類型器紧,所以不會(huì)受影響.

5.過(guò)濾如下數(shù)組,只保留正數(shù)楼眷,直接在原數(shù)組上操作

var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
  for (var i in arr) {
    if (arr[i] <= 0) {
      arr.splice(i, 1)
      filter(arr)
    }
  }
}
filter(arr)
console.log(arr) // [3,1,2]

6.過(guò)濾如下數(shù)組铲汪,只保留正數(shù),原數(shù)組不變罐柳,生成新數(shù)組

var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
  var newArr = []
  var j = 0
  for (var i in arr) {
    if (arr[i] > 0) {
      newArr[j++] = arr[i]
    }
    
  }
  return newArr
}
var arr2 = filter(arr)
console.log(arr2) // [3,1,2]
console.log(arr)  // [3,1,0,-1,-2,2,-5]

7.寫一個(gè)深拷貝函數(shù)掌腰,用兩種方式實(shí)現(xiàn)

一、遞歸實(shí)現(xiàn)深復(fù)制
  function copy(obj) {
    var newObj = {}
    for (var x in obj) {
      if (obj.hasOwnProperty(x)) {
        if (typeof obj[x]==="number" || 
            typeof obj[x]==="string" ||
            typeof obj[x]==="boolean" ||
            typeof obj[x]==="undefined" ||
            obj[x]===null) {
              newObj[x] = obj[x]
        } else {
          newObj[x] = copy(obj[x])
        } 
      }
    }
    return newObj;
  }

  二张吉、JSON方法實(shí)現(xiàn)深復(fù)制
  function copy(obj) {
    var str = JSON.stringify(obj)
    return JSON.parse(str)
  }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末齿梁,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子肮蛹,更是在濱河造成了極大的恐慌勺择,老刑警劉巖,帶你破解...
    沈念sama閱讀 207,248評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件伦忠,死亡現(xiàn)場(chǎng)離奇詭異省核,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)昆码,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門气忠,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)邻储,“玉大人,你說(shuō)我怎么就攤上這事旧噪《帜龋” “怎么了?”我有些...
    開封第一講書人閱讀 153,443評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵淘钟,是天一觀的道長(zhǎng)宦赠。 經(jīng)常有香客問(wèn)我,道長(zhǎng)米母,這世上最難降的妖魔是什么袱瓮? 我笑而不...
    開封第一講書人閱讀 55,475評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮爱咬,結(jié)果婚禮上尺借,老公的妹妹穿的比我還像新娘。我一直安慰自己精拟,他們只是感情好燎斩,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,458評(píng)論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蜂绎,像睡著了一般栅表。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上师枣,一...
    開封第一講書人閱讀 49,185評(píng)論 1 284
  • 那天怪瓶,我揣著相機(jī)與錄音,去河邊找鬼践美。 笑死洗贰,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的陨倡。 我是一名探鬼主播敛滋,決...
    沈念sama閱讀 38,451評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼兴革!你這毒婦竟也來(lái)了绎晃?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,112評(píng)論 0 261
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤杂曲,失蹤者是張志新(化名)和其女友劉穎庶艾,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體擎勘,經(jīng)...
    沈念sama閱讀 43,609評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡咱揍,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,083評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了货抄。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片述召。...
    茶點(diǎn)故事閱讀 38,163評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡朱转,死狀恐怖蟹地,靈堂內(nèi)的尸體忽然破棺而出积暖,到底是詐尸還是另有隱情,我是刑警寧澤怪与,帶...
    沈念sama閱讀 33,803評(píng)論 4 323
  • 正文 年R本政府宣布夺刑,位于F島的核電站,受9級(jí)特大地震影響分别,放射性物質(zhì)發(fā)生泄漏遍愿。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,357評(píng)論 3 307
  • 文/蒙蒙 一耘斩、第九天 我趴在偏房一處隱蔽的房頂上張望沼填。 院中可真熱鬧,春花似錦括授、人聲如沸坞笙。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)薛夜。三九已至,卻和暖如春版述,著一層夾襖步出監(jiān)牢的瞬間梯澜,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工渴析, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留晚伙,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,636評(píng)論 2 355
  • 正文 我出身青樓俭茧,卻偏偏與公主長(zhǎng)得像撬腾,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子恢恼,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,925評(píng)論 2 344

推薦閱讀更多精彩內(nèi)容

  • 引用類型有哪些民傻?非引用類型有哪些 引用類型:對(duì)象、數(shù)組场斑、函數(shù)漓踢、正則非引用類型:string、number漏隐、bool...
    柏龍閱讀 312評(píng)論 0 2
  • 第5章 引用類型(返回首頁(yè)) 本章內(nèi)容 使用對(duì)象 創(chuàng)建并操作數(shù)組 理解基本的JavaScript類型 使用基本類型...
    大學(xué)一百閱讀 3,212評(píng)論 0 4
  • 每天都有喜歡的小紫薯喧半,胡蘿卜,南瓜青责,山藥各種小樣當(dāng)下午甜品挺据。生活就應(yīng)該五彩繽紛 愿我喜歡的你們安康取具,幸悅
    微笑吧_微笑閱讀 134評(píng)論 0 0
  • 文/國(guó)境之南 1. 入秋暇检。 陰雨連綿。屋子里沒(méi)有了悶悶熱婉称,變得涼爽起來(lái)块仆,點(diǎn)滴小雨在一陣秋風(fēng)中變的格外調(diào)皮,它舞動(dòng)著...
    國(guó)境之南_閱讀 3,220評(píng)論 86 78