知識點:html
JavaScript 函數對參數的值(arguments)沒有進行任何的檢查。算法
JavaScript 函數參數與大多數其餘語言的函數參數的區別在於:它不會關注有多少個參數被傳遞,不關注傳遞的參數的數據類型。數組
JavaScript 函數定義時參數沒有指定數據類型。函數
JavaScript 函數對隱藏參數(arguments)沒有進行檢測。spa
JavaScript 函數對隱藏參數(arguments)的個數沒有進行檢測。code
==============================================================htm
arguments對象表明傳入參數,組成的一個數組:對象
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>W3Cschool教程(w3cschool.cn)</title> </head> <body> <p>查找最大的數。</p> <p id="demo"></p> <script> //算法:1.若是隻有一個參數,直接返回 // 2.有多個參數,則和max默認值一一比對,max小於它的,就把它賦值給max,最後返回max x = findMax(1, 123, 500, 115, 44, 88); function findMax() { var i,max=arguments[0]; if (arguments.length<2)return max; for(i=0;i<arguments.length;i++){ if(max<arguments[i])max=arguments[i]; } return max; } document.getElementById("demo").innerHTML = x; </script> </body> </html>
給函數參數,參數若是不設置,默認值爲undefined,建議給參數設置默認值,寫法一:blog
function myFunction(x, y) { if (y === undefined) { y = 0; } }
給函數參數設置默認值寫法二(若是y已經定義 , y || 0返回 y, 由於 y 是 true, 不然返回 0, 由於 undefined 爲 false):教程
function myFunction(x, y) { y = y || 0; }
用【arguments對象】來計算全部傳入參數的和:
x = sumAll(1, 123, 500, 115, 44, 88); function sumAll() { var i, sum = 0; for (i = 0; i < arguments.length; i++) { sum += arguments[i]; } return sum; }
在函數中調用的參數是函數的參數。
若是函數修改參數的值,將不會修改參數的初始值(在函數外定義)。
總結:JavaScript函數傳值只是將參數的值傳入函數,函數會另外配置內存保存參數值,因此並不會改變原參數的值
var x = 1; // 經過值傳遞參數 function myFunction(x) { x++; //修改參數x的值,將不會修改在函數外定義的變量 x console.log(x); } myFunction(x); // 2 console.log(x); // 1
在JavaScript中,能夠引用對象的值。
所以咱們在函數內部修改對象的屬性就會修改其初始的值。
修改對象屬性可做用於函數外部(全局變量)
var obj = {x:1}; // 經過對象傳遞參數 function myFunction(obj) { obj.x++; //修改參數對象obj.x的值,函數外定義的obj也將會被修改 console.log(obj.x); } myFunction(obj); // 2 console.log(obj.x); // 2