JavaScript中的变量

变量类型

  • 基本类型
  • 引用类型

基本类型

类型:Undefined 、 Null 、 Boolean 、 Number 和 String ---- 按值访问

  • 复制变量值
    var num1 = 5;
    var num2 = num1;
    
    在这里插入图片描述
    这两个变量可以参与任何操作而不会相互影响

引用类型

类型:Object ---- 按引用访问

当复制保存着对象的某个变量时,操作的是对象的引用。但在为对象添加属性时,操作的是实际的对象

  • 复制变量值
    在这里插入图片描述
var obj1 = new Object();
var obj2 = obj1;
obj1.name = "Nicholas";
alert(obj2.name); //"Nicholas"

这个值的副本实际上是一个指针,而这个指针指向存储在堆中的一个对象。复制操作结束后,两个变量实际上将引用同一个对象。因此,改变其中一个变量,就会影响另一个变量

传递参数

ECMAScript 中所有函数的参数都是按值传递

  • 在向参数传递基本类型的值时,被传递的值会被复制给一个局部变量(即命名参数,或者用ECMAScript 的概念来说,就是 arguments 对象中的一个元素)
  • 在向参数传递引用类型的值时,会把这个值在内存中的地址复制给一个局部变量,因此这个局部变量的变化会反映在函数的外部
    demo:
    function addTen(num) {
    	num += 10;
    	return num;
    }
    var count = 20;
    var result = addTen(count);
    alert(count); //20,没有变化
    alert(result); //30
    
    function setName(obj) {
    	obj.name = "Nicholas";
    }
    var person = new Object();
    setName(person);
    alert(person.name); //"Nicholas"
    
    function setName(obj) {
    	obj.name = "Nicholas";
    	obj = new Object();
    	obj.name = "Greg";
    }
    var person = new Object();
    setName(person);
    alert(person.name); //"Nicholas"
    
    实际上,当在函数内部重写 obj 时,这个变量引用的就是一个局部对象了。而这个局部对象会在函数执行完毕后立即被销毁。

检测类型

  • typeof
    typeof 操作符是确定一个变量是字符串、数值、布尔值,还是 undefined 的最佳工具
  • instanceof
    想知道它是什么类型的对象
    语法:result = variable instanceof constructor
    alert(person instanceof Object); // 变量 person 是 Object 吗?
    alert(colors instanceof Array); // 变量 colors 是 Array 吗?
    alert(pattern instanceof RegExp); // 变量 pattern 是 RegExp 吗?
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值