对于var a=b=3的理解

天偶然间看到有一个笔试题是这样的:

(function(){
var a=b=3;
})();
console.log(typeof a!=='undefined');
console.log(typeof b!=='undefined');

问输出结果是什么:

起初我的判断是俩个都是false,因为我的理解是变量a,b在匿名函数里面是局部变量,在全局范围是没有效果的。 
可最终结果却是 false true 
很是郁闷,最终经过参考别的讲解,发现,原来是我对var=a=b=3的理解错误。

我的理解是:var a=3,var b=3;
正确的理解是:从右向左,b=3,var a=b;

由此不难看出b没有声明,而是直接赋值,可作为全局变量, 
而a则在函数中进行了声明,并把b的值赋值给a ,a作为局部变量。
 

### JavaScript 变量声明与初始化 在 JavaScript 中,`var` 是用于声明变量的关键字之一。当使用 `var` 声明一个变量时,如果没有为其指定初始值,则该变量会被声明,但其初始值为 `undefined`,直到代码将其赋值[^1]。 以下是关于变量声明和初始化的一个例子: ```javascript // 声明变量 b 并立即初始化为 2 var b = 2; console.log(b); // 输出: 2 ``` 在这个例子中,变量 `b` 被声明并被赋予了一个初始值 `2`。这被称为 **初始化**,即第一次给变量分配值的过程[^2]。 如果仅声明变量而未对其进行初始化,则会得到如下情况: ```javascript var c; console.log(c); // 输出: undefined ``` 这是因为虽然变量已被声明,但由于尚未赋值,JavaScript 默认将其设置为 `undefined`[^3]。 另外,在条件语句中也可以看到类似的逻辑应用。例如嵌套的 `if` 语句可以用来进一步细化判断过程[^4]: ```javascript var x = prompt("Enter a number:"); x = parseInt(x); if (typeof x === "number") { if (x === 5) { console.log('The value is exactly 5.'); } } ``` 上述代码展示了如何通过用户输入来执行更复杂的操作,并强调了数据类型的转换对于精确比较的重要性。 #### 注意事项 - 如果尝试访问一个从未声明过的变量,将会抛出 ReferenceError 错误。 - 已经声明但未初始化的变量返回的是 `undefined`,而不是错误。 ### 结论 综上所述,理解变量声明与初始化的区别以及它们的行为模式是非常重要的。正确处理这些概念可以帮助开发者编写更加健壮和可维护的代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值