<dfn id="w48us"></dfn><ul id="w48us"></ul>
  • <ul id="w48us"></ul>
  • <del id="w48us"></del>
    <ul id="w48us"></ul>
  • JavaScript中的傳值與傳引用的理解

    時間:2024-10-12 06:06:58 JavaScript 我要投稿
    • 相關(guān)推薦

    關(guān)于JavaScript中的傳值與傳引用的理解

      1.傳值(by value)

      變量的值被復(fù)制出一份,與原來的值將不相干,也就是說即使新的值被修改,原來的值也不會改變,在JavaScript中基本類型都是傳值的.

      復(fù)制代碼 代碼如下:

      function testPassValue()

      {

      var m=1;

      var n=2;

      //將m,n的值復(fù)制一份,傳遞到passValue

      passValue(m,n);

      alert(m); //將是原有的值

      }

      function passValue(a,b)

      {

      a = a+b; //改變a的值,這里a只是原有值的一份copy

      alert(a);

      }

      輸出結(jié)果:

      3

      1

      2.傳引用(by reference).

      引用本身復(fù)制一份傳給function,引用指向的對象并沒有被復(fù)制傳遞(java中也是如此),在function中,如果改變了對象的屬性的值,由于和原來的引用指向的是同一個對象,因此在通過原來的引用訪問到的將是修改過的值;

      但是如果只是在function中將引用指向一個新的對象,將不會改變原對象的值,改變的只是復(fù)制的這一份引用.

      復(fù)制代碼 代碼如下:

      function testPassValue()

      {

      var date = new Date(2006,02,27);

      alert(date.getDate()); //輸出為 27

      //將date引用本身復(fù)制一份,傳遞到passReference,注意date所指向的對象并沒有被復(fù)制

      passReference(date);

      alert(date.getDate()); //輸出為12

      //同上

      changeReference(date);

      alert(date.getDate()); //輸出還為12

      }

      function passReference(da)

      {

      //由于da和原引用指向的是同一個對象,在function外,通過原有的引用訪問到的將是對象的日期屬性值,將是修改之后的值.

      da.setDate(12);

      }

      function changeReference(da)

      {

      //此時da引用實際上是原引用的一份copy,將引用本身重新賦值,將不會影響原引用

      da= new Date(2007,05,11);

      //將da引用指向一個新的對象,此時原引用指向的還是原來的對象

      alert(da.getDate()); // 輸出為11

      }

      3 特殊的String

      在JavaScript中,String也傳引用的. js中只有charAt方法,而沒有對應(yīng)的修改方法,和java中的String相同,都具有不變性.

      復(fù)制代碼 代碼如下:

      var s1 = "hello";

      var s2 = "hell" + "o";

      if (s1 == s2)

      alert("s1 = s2"); //這句會不會執(zhí)行? java用的熟的人可能會認(rèn)為不會執(zhí)行(這句話我頗有微詞,java中也是會執(zhí)行的!),因為java中的==比較的是同一性. 事實上在js中對String==比較的是值是否相等,所以這句話會執(zhí)行. 但是對其他的Object == 比較和java中一樣是同一性.

    【JavaScript中的傳值與傳引用的理解】相關(guān)文章:

    Java方法(函數(shù))傳值和傳引用的問題10-07

    對javascript的理解08-08

    淺談javascript中的單線程理解08-16

    有關(guān)深入理解JavaScript中的并行處理的介紹10-14

    理解JavaScript原型鏈教程09-02

    javascript的閉包概念怎么理解06-15

    JavaScript中的with關(guān)鍵字07-24

    在Java中執(zhí)行JavaScript代碼07-14

    Javascript中typeof 用法歸納09-27

    主站蜘蛛池模板: 亚洲国产精品自产在线播放| 99精品视频在线观看免费| 亚洲AV无码精品色午夜在线观看| 91精品国产高清久久久久久91| 久久夜色精品国产网站| 国内精品久久久久久久影视麻豆| 99久久久精品免费观看国产| 亚洲精品乱码久久久久久不卡| 国产精品成人小电影在线观看| 97精品国产福利一区二区三区| 亚洲精品乱码久久久久久按摩| 久久五月精品中文字幕| 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲 | 91精品国产9l久久久久| 亚洲精品中文字幕无码蜜桃| 国产区精品福利在线观看精品| 一区二区三区四区精品视频| 成人国产精品999视频| 精品无人码麻豆乱码1区2区| 自拍偷自拍亚洲精品被多人伦好爽| 欧美ppypp精品一区二区| 黑巨人与欧美精品一区 | 国产91精品一区二区麻豆网站 | 亚洲av永久无码精品漫画| 亚洲精品A在线观看| 久久人人超碰精品CAOPOREN| 国产乱人伦偷精品视频免观看 | 国产精品视频二区不卡| 嫩草伊人久久精品少妇AV| 亚洲国产精品无码久久久秋霞2 | 国产精品免费看久久久香蕉| 91精品国产91久久久久久青草 | 2022国产精品不卡a| 国产精品久久久久久吹潮| 精品无码人妻夜人多侵犯18| 日本一卡精品视频免费| 亚洲人精品午夜射精日韩 | 精品无码久久久久久久动漫| 久久99精品久久久久久齐齐| 精品无码人妻久久久久久| 欧美精品亚洲人成在线观看|