<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    網絡上看到一篇文章,《JavaScript 傳遞參數是值傳遞?還是值傳遞啊?》

    地址:http://www.xiaoxiaozi.com/2010/03/05/1719/

    當然看這之前我是很清晰知道基本數據類型傳值,引用數據類型傳引用。

    剛看了個開頭就有點暈了,文章所說:

    “在本文開頭,首先,十萬以及萬分肯定的說一句,JavaScript 函數傳遞參數時,是值傳遞。”

    有興趣的朋友可以去看原文。 我看了之后就順手寫起了示例代碼:

    (1) 典型傳值

    function setName(name)
                {
                    name 
    = "test";
                }
                
    var person = new Object();
                person.name 
    = " hechangmin ";
                
                setName(person.name);
                alert(person.name); 
    // hechangmin


    (2) 典型的傳引用

    function setName(obj)
                {
                    obj.name 
    = "test";
                }
                
    var person = new Object();
                person.name 
    = " hechangmin ";
                
                setName(person);
                alert(person.name); 
    // test

    我想大家對輸出的結果都沒異議。這也是我記憶中的理解。

    下面帶領大家看一些可能引起大家議論的示例:

    var x = new Object();
                x.name 
    = "test";
                    
                
    function setName(obj)
                {
                    obj 
    = x;
                    alert(obj 
    == x);    // true 因為上一句進行了賦值操作
                }
                
    var person = new Object();
                person.name 
    = " hechangmin ";
                
                setName(person);
                alert(person.name); 
    // hechangmin
                alert(person == x); // false 

    傳進去的 person 肯定是 引用數據類型。(這點沒歧義)

    進去后發現 給引用賦以新值 x 。函數內部 alert(obj == x); 也輸出了 true

    說明賦值是成功的。

    而函數執行完畢,發現值依然沒變。 就這個結果來看,說是傳值還真沒什么說不過去的。

    但是我隨后在 http://m.tkk7.com/magicdoom/archive/2006/02/27/32555.html  (建議有興趣的朋友可以看看)找到一篇講 javascript 傳值 傳引用的文章。

    文章有說傳遞進去的引用型參數,在內部如果直接對引用參數賦值。 javascript 會自動生成一份copy ,而不去影響原有的引用。

    ===========

    綜上所述 ,基本就都明白。文章寫到這里基本就接近尾聲,不過這里提到了 javascript string , 下次有機會總結關于 string 的神奇后,再和大家分享交流。

    posted on 2010-03-18 16:12 -274°C 閱讀(7677) 評論(3)  編輯  收藏 所屬分類: web前端


    FeedBack:
    # re: 關于傳值和傳引用的插曲
    2011-01-22 09:18 | ffff
    fffffff  回復  更多評論
      
    # re: 關于傳值和傳引用的插曲
    2011-01-22 09:23 | ffff
    這個很容易理解嘛,
    在函數里,那個obj不是被換成x了嗎?
    本來obj是保存person的引用,當執行了obj=x;時,obj就被改編成保存x的引用了。根本就沒有什么特別需要強調的吧?  回復  更多評論
      
    # re: 關于傳值和傳引用的插曲
    2014-07-11 09:24 | bandit
    大家不要看這篇文章 本來很簡單的事情反而被博主繞復雜了,  回復  更多評論
      

    常用鏈接

    留言簿(21)

    隨筆分類(265)

    隨筆檔案(242)

    相冊

    JAVA網站

    關注的Blog

    搜索

    •  

    積分與排名

    • 積分 - 914354
    • 排名 - 40

    最新評論

    主站蜘蛛池模板: 国产精品成人免费视频网站京东 | 色吊丝最新永久免费观看网站| 久久精品国产亚洲AV麻豆王友容| 久久九九免费高清视频| 免费在线黄色网址| 免费人成在线观看播放a| 亚洲成a人无码av波多野按摩 | 亚洲视频一区在线| 最近2019免费中文字幕6| 18亚洲男同志videos网站| 99视频免费观看| 亚洲中文字幕人成乱码| 无人在线观看完整免费版视频| 亚洲人成小说网站色| 日韩a在线观看免费观看| 国产成人精品日本亚洲语音| 亚洲Aⅴ无码一区二区二三区软件 亚洲AⅤ视频一区二区三区 | 亚洲天堂电影在线观看| 一个人免费观看www视频在线| 国产亚洲国产bv网站在线| 最新仑乱免费视频| 精品久久久久亚洲| 久久乐国产精品亚洲综合| 永久免费不卡在线观看黄网站| 午夜亚洲国产理论秋霞| 18禁止看的免费污网站| 亚洲人成未满十八禁网站| 又爽又黄无遮挡高清免费视频| 国产精品美女久久久免费 | 免费精品视频在线| 久久亚洲精品中文字幕三区| 在线免费观看国产| 亚洲色偷偷偷综合网| 久久精品国产亚洲5555| 亚洲成人免费网站| 国产区图片区小说区亚洲区| 亚洲精品乱码久久久久久中文字幕| 50岁老女人的毛片免费观看| 亚洲AV无码资源在线观看| 亚洲男人的天堂www| 114一级毛片免费|