JavaScript作用域
我们知道Javascript中的变量是松散类型的,它的值和类型在脚本生命周期内都可以改变。Javascript变量可以保存两种不同类型的值:基本类型和引用类型
基本类型:简单的数据段
引用类型:多个值构造的对象
在将一个值赋给变量是,解析器必须确定这个是基本类型还是引用类型,引用类型是保存在内存中的对象,Javascript不允许直接访问内存位置,所以在操作对象时实际上是操作对象的引用而不是实际的对象,即是按引用访问的
引用类型的动态性
对于引用类型,我们可以动态的为其添加属性和方法,而基本类型则不可这样操作
1 var person=new Object(); 2 person.name="Jack"; 3 alert(person.name); //Jack
PS:这种方法对于基本类型是无效的
变量的赋值方式
①基本类型的赋值
把一个基本类型的值赋值给另一个变量,会在这个变量上面创建该值的副本,然后分配到新变量的位置,这个两个变量的值,完全独立,互不影响
②引用类型的赋值
把一个引用类型的值赋值给另一个变量,会将存储对象位置的指针赋值给新变量,这个两个变量实际引用了同一个对象,改变其中一个变量就会影响另一个变量
1 var obj1=new Object(); 2 var obj2=obj1; 3 obj1.name="Jack"; 4 alert(obj2.name); //Jack
函数参数的传递方式
在Javascript中所有函数的参数都是按值传递的,在想参数传递值时,被传递的值会被赋值一个给局部变量,即命名参数,也就是arguments对象中的一个元素。当然对于引用类型,实际上赋值的对象的引用
下面看两个例子:
function add(num){ num+=100; return num; } var count=50; var result=add(count); alert(count); alert(result);
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。