首頁 >web前端 >js教程 >JavaScript基礎篇之變數作用域、傳值、傳址的簡單介紹與實例_javascript技巧

JavaScript基礎篇之變數作用域、傳值、傳址的簡單介紹與實例_javascript技巧

WBOY
WBOY原創
2016-05-16 17:31:011109瀏覽

javascript:变量的声明
以下是几种声明变量的方式

复制代码 代码如下:

 var value;
 var value,value1,value2;//同时声明多个变量,但是这些变量的值都是undefined
 var i = 0,j = 0,k=100;//变量声明,初始化一体。
 //如果大家尝试读一个不存在的变量(值)会报错!但是尝试给一个未使用Var声明的变量赋值,javascript
 //会隐式的声明改变量,而且声明了的变量还是全局的。细节:所以大家创建变量都尽量使用Var
 //变量的作用域(这个问题也容易出,大家要搞明白)

javascript:变量的作用域
 这些都是细节,和我一样初学的一定要注意避免!
复制代码 代码如下:

var golbal = "golbal"; //全局变量
 var local ="local";
function area()
 {
//局部变量的优先级比全局变量的高
var local = "arealocal"
//当函数体内声明的变量名和全局变量名相同时,javascript 会隐藏全局变量
var golbal ="areagolbal";

document.write("local is :"+local + "and golbal is :" + golbal +"
");
 }

area();
//输出:local is :arealocaland golbal is :areagolbal

在嵌套的函数里面定义局部变量,效果会怎么样呢?看下面:
复制代码 代码如下:

var hope = "moremoney";
function createmore()
{
var hope = "have more money";//局部
function createmoreto()//嵌套函数
{
var hope = "have more money to much";//局部
document.write("Createmoreto hope is :"+hope +"
");
  //输出:Createmoreto hope is :have more money to much
}
 createmoreto();//调用
 document.write("Createmore hope is :" +hope +"
");
//输出:Createmore hope is :have more money
}
 createmore(); //调用

javascript:传值和传址
这里也是比较重要的概念!不要漏了。

  传值 传址
复制 实际复制的值,存在不同的、独立的拷贝。 复制的只是对数字的引用。如果通过这个新的引用修改了数值,这个改变对最初的引用来说也是可见的。
传递 传递给函数的是值的独立拷贝对它的改变在函数外没有影响 传递给函数的是对数值的引用,如果函数通过传递给它的引用修改了数值,这个改变也是可见的。
比较 比较这两个对立的值,通常逐字节的比较,以判断是否相等 比较的是两个引用,以判断它们引用的是否是同一个数值。

javascript:基本型別與引用型別

javascript的基本規則是:基本型別透過傳值來操作,引用型別透過傳址來操作。 (什麼事值類型,或什麼事引用看我上一篇)
按值傳遞

複製程式碼


程式碼如下:


 var value = 1;
 var copyvalue = value; //將value賦給另一個變數
  function addTotal(total,arg)  {
 total = arg; //total = total arg 效果等同
 }
 //呼叫函數,傳兩個參數(大家可能會認為這個函數改變了全域變數的值,其實沒有,函數用的也是對立拷貝)
 addTotal(value,copyvalue);
 if(value == 1) copyvalue = 2;
 document.write("total t" value "and copyvalue tt copyvalue
");
 //最後輸出:total 1and copyvalue 2
按址傳遞複製程式碼

程式碼如下:


 var array = new Array("Javascccp");

 {
 arr[0] = "JAVASCRIPT";
 }
 //沒呼叫函數前
 document.write(array[0] "
");
 //輸出Javascccp;
 //呼叫函數後
 modifyArray(array);
 document.write(array[0] "
");
 //輸出大寫JAVASCRIPT
 //透過修改objarray會是相同的效果
 objarray[0] = "Frank";
 document.write(array[0] "
");
  //輸出Frank;


小結:上面內容希望大家不要錯過,對學習後面的知識還是很有幫助的!
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn