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

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

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

    網(wǎng)絡(luò)上看到一篇文章,《JavaScript 傳遞參數(shù)是值傳遞?還是值傳遞啊?》

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

    當(dāng)然看這之前我是很清晰知道基本數(shù)據(jù)類型傳值,引用數(shù)據(jù)類型傳引用。

    剛看了個(gè)開頭就有點(diǎn)暈了,文章所說:

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

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

    (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

    我想大家對(duì)輸出的結(jié)果都沒異議。這也是我記憶中的理解。

    下面帶領(lǐng)大家看一些可能引起大家議論的示例:

    var x = new Object();
                x.name 
    = "test";
                    
                
    function setName(obj)
                {
                    obj 
    = x;
                    alert(obj 
    == x);    // true 因?yàn)樯弦痪溥M(jìn)行了賦值操作
                }
                
    var person = new Object();
                person.name 
    = " hechangmin ";
                
                setName(person);
                alert(person.name); 
    // hechangmin
                alert(person == x); // false 

    傳進(jìn)去的 person 肯定是 引用數(shù)據(jù)類型。(這點(diǎn)沒歧義)

    進(jìn)去后發(fā)現(xiàn) 給引用賦以新值 x 。函數(shù)內(nèi)部 alert(obj == x); 也輸出了 true

    說明賦值是成功的。

    而函數(shù)執(zhí)行完畢,發(fā)現(xiàn)值依然沒變。 就這個(gè)結(jié)果來看,說是傳值還真沒什么說不過去的。

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

    文章有說傳遞進(jìn)去的引用型參數(shù),在內(nèi)部如果直接對(duì)引用參數(shù)賦值。 javascript 會(huì)自動(dòng)生成一份copy ,而不去影響原有的引用。

    ===========

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

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


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

    常用鏈接

    留言簿(21)

    隨筆分類(265)

    隨筆檔案(242)

    相冊

    JAVA網(wǎng)站

    關(guān)注的Blog

    搜索

    •  

    積分與排名

    • 積分 - 914507
    • 排名 - 40

    最新評(píng)論

    主站蜘蛛池模板: 牛牛在线精品观看免费正| 亚洲欧洲精品成人久久曰| 中文字幕不卡免费视频| 亚洲国产午夜福利在线播放| 污视频网站免费观看| 无码欧精品亚洲日韩一区夜夜嗨 | 中文免费观看视频网站| 亚洲黄色网站视频| 131美女爱做免费毛片| 久久亚洲国产成人精品性色| 中文字幕免费观看| 久久国产亚洲电影天堂| 国内精品免费在线观看| 久久亚洲AV无码精品色午夜麻豆| **一级一级毛片免费观看| 国产精品亚洲自在线播放页码 | 中文毛片无遮挡高清免费| 亚洲熟女一区二区三区| 久久免费观看国产精品88av| 亚洲视频免费在线观看| 亚洲天堂免费在线| 爱情岛论坛亚洲品质自拍视频网站 | 久久夜色精品国产噜噜噜亚洲AV| 91福利视频免费| 最新国产成人亚洲精品影院| 国内外成人免费视频| 无遮挡国产高潮视频免费观看| 国产亚洲美女精品久久久| 久久久久免费看黄a级试看| 亚洲国产成人精品电影| 日韩成人免费aa在线看| 在线观看亚洲免费视频| 久久亚洲综合色一区二区三区| 亚洲一区二区在线免费观看| 久久久久亚洲AV无码专区体验| 免费人成在线观看网站| 亚洲一区二区三区亚瑟| 伊在人亚洲香蕉精品区麻豆| 日本一卡精品视频免费| 亚洲va乱码一区二区三区| 国内精品久久久久久久亚洲|