DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript基礎知識 >> Js從頭學起(基本數據類型和引用類型的參數傳遞詳細分析)
Js從頭學起(基本數據類型和引用類型的參數傳遞詳細分析)
編輯:JavaScript基礎知識     
1、基本數據類型傳遞參數:
復制代碼 代碼如下:
  funciton addTen(num){
    num+=10;
    return num;
  }
  var count=20;
  var result=addTen(count);
  alert(count);//20
  alert(resullt);//30

  執行結果是:20和30。在這段代碼中,將變量count當做參數傳遞給了函數addTen,也就是相當於將變量count的值復制給了函數addTen的參數。這時addTen的參數num可以看做是函數內部的一個變量。在上段代碼中,就相當於兩個基本數據類型變量之間的值復制。而基本數據類型都有自己獨立的內存地址,所以num和count是沒有任何關系的,他們只是值相等而已,函數執行完畢後,count的值並沒有改變。而函數外面的result是被直接賦值的,所以result的值就是函數的結果30。
  2、引用類型傳遞參數:
復制代碼 代碼如下:
  function setName(obj){
    obj.name="LSN";
  }
  var person=new Object();
  setName(person);
  alert(person.name);//LSN

  執行結果是:LSN。在這段代碼中,函數setName的作用是給obj對象添加了一個屬性name並給該屬性賦值為"LSN",因為obj是引用類型,所以這裡屬於是將引用類型person賦值給了obj,也就是說person和obj引用了一個內存地址,所以當給obj新加了屬性name時,在函數外面的person也跟著改變,最後person.naem的結果為LSN。
  3、引用類型傳遞參數到底傳的是值還是引用?
復制代碼 代碼如下:
  function setName(obj){
    obj.name="ABC";
    obj=new Object();
    obj.name="BCD";
  }
  var person=new Object();
  setName(person);
  alert(person.name);// ABC

  執行結果是:ABC。實例3與實例2的區別是在函數中又加了2行代碼,在給obj對象新加一個屬性name並賦值後 又將obj定義成了一個新的對象(new Object()),定義新對象後又name賦上新的值“BCD”。這個時候如果是按引用傳遞的話,那麼最後person對象就會自動修改為指向其name屬性為"BCD"的新對象,但最後顯示的卻是“ABC”,這說明即使在函數內部修改了參數的值,但原始的引用還保持不變。實際上,當在函數內部obj=new Object()時 這個新的obj就已經成為函數內部的局部對象了,這個對象會在函數執行完畢後自動銷毀。
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved