- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这一切都始于这些简单的代码行:
a = 3;
b = 2;
function line(x) {
var a = 5;
var b = 4;
return a*x+b;
}
// returns 17
b = line(a) - b;
alert(b);
// returns 36
c = line(a) + b;
alert(c);
两个警报分别返回 17 和 36。
该控件按预期工作。直到……
我改错了
函数内部像这样:
function line(x) {
var a = 5;
b = 4;
return a*x+b;
}
突然第13行返回15,第17行返回23
当我跟随 var
时,情况继续恶化
在兔子洞里,随着我下降而变得更加陷入困境。
我意识到我可以记下始终使用 var
安息吧,我的代码将始终按预期工作
但这现在已经成为原则问题,现在我需要
了解 var
的实际工作原理。
这里有四个 hell 的链接,
由我(也可能为)我制作:
谜语 #1 http://jsfiddle.net/js_test/gNEmY/
谜语#2 http://jsfiddle.net/js_test/FJVYL/
谜语 #3 http://jsfiddle.net/js_test/Vz7Sd/
谜语 #4 http://jsfiddle.net/js_test/RaA5J/
如果有人能给我一些见解
了解引擎盖下发生的事情
也就是说,每次调用 alert() 时会发生什么;
我真的很感激。
最佳答案
var
创建一个局部变量,作用域为它出现的函数。在全局范围内声明的任何变量都成为全局对象的属性(在浏览器中,window
),以及在函数中引用的任何未使用 var
声明的变量> 在那个函数中指的是周围的范围,很可能是全局范围。
还有一个新的关键字,let
,它将出现在即将发布的 ECMAScript 版本中,并且已经出现在一些浏览器中,它创建了一个 block 范围的变量。
因此,在您的第一个示例中(我假设它在浏览器中运行),您创建了 window.a
和 window.b
,它们绑定(bind)到分别为 3 和 2。函数 line
声明了局部变量 a
和 b
。当 window.a 传递给 line 时,参数 x
被绑定(bind)到值 3(window.a 的值)。局部变量a
和b
分别为5 和4。 这些与 window.a 和 window.b 无关。计算 a*x+b
因此是 5*3+4,即 19。 p>
代码b = line(a) - b
将window.a
传递给line
,计算出值19,减去当前值window.b
从它 (2),得到 17,然后将其分配给 window.b
。 36的值来自line(3)
(仍然是19)加上17(window.b
的新值)。
当您在函数 line
中从对 b
的赋值中删除 var
时,您更改了它以便 b
不再是局部变量。 在这种情况下,函数中对 b
的所有引用都引用全局值 window.b。
在你的 Riddle #2 的情况下,你得到 23,在第一次调用 window.b 后等于 15。当 line(a) 被第二次调用时,window.b 被设置回 4, a*x+b计算还是得到19,然后再次加上window.b(4),得到23。
重要的是要注意,var
关键字声明的变量是函数范围的,而不是您可能对其他 C 派生语言所期望的 block 范围的变量。例如,在这个函数中:
function scope(array) {
var a = 7;
for (var b = 0; b < array.length; ++b) {
var c = array[b];
}
alert(a + b + c);
}
所有变量的范围都扩展到整个函数。特别是,c
的范围不限于for
循环。
但是,未在特定范围内声明的变量不一定引用全局变量。如果它嵌套在另一个函数范围内,它将引用该嵌套范围。考虑以下示例:
var b = 7;
function outer() {
var b = 42;
function inner() {
return b; // refers to b in outer, not global
}
return inner();
}
alert(outer()); // 42, not 7
关于javascript - 变量作用域和 Var,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21082985/
这个问题已经有答案了: Can I bind an array to an IN() condition in a PDO query? (23 个回答) 已关闭 5 年前。 任何人都可以看到我如何在
我阅读了关于此的 bash 手册页,但我不明白其中的区别。我对它们进行了测试,它们似乎产生了完全相同的结果。 如果值不是通过命令行参数设置的,我想设置一个变量的默认值。 #!/bin/bash var
我为我的网站开了一家商店,并让它运行起来,但我意识到它无法正确购买商品。换句话说,您不会走进一家商店,拿起一件商品,购买,再次购买,购买,再次购买,等等,以获得想要的数量。你一次捕获他们。我的网站缺少
基本上,我想知道为什么会这样(将列表的内存地址作为参数传递): void init_lista (elemPtr *list) { *list = NULL; } int main(){
看到这个问题:Is there a (built-in) way in JavaScript to check if a string is a valid number?还有这个:jsperf ,其
我有以下字符串: 我想用正则表达式替换所有后面有 px 的数字,并用 X 乘以它们的值。 (X 是一个变量)。 所以如果X=3,结果就是 请注意 X 必须是我将检索到函数的变量 最佳答案 以下代码
这个问题在这里已经有了答案: 关闭 13 年前。 同时 (var != var) System.out.println("循环.."); 执行它..如何声明..var
我只是好奇。我想知道表达式是否有特定原因 var &= expr 行为方式与不同 var = var && expr. 看起来第一个表达式中的表达式正在执行,而不管 var 上的 false 值。 我
我有这个 Ruby 代码: var1 = 10 puts var1.object_id var1 = var1 + 0 puts var1.object_id var1 = var1 + 1 puts
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: demote boost::function to a plain function pointer 所以我
好吧,堆栈溢出, 我花了几个小时来解决 javascript 中的问题(在 NodeJS 服务器中编写),但我真的不明白。 这就是发生的事情: var data = {x: 50}; var temp
首先,我在这里处理 1 和 0,我很清楚 1 == true 和 0 == false。但是我很好奇为什么这不起作用: $var = 1; echo $var; /* 1 */ $var = $var
标题说的是什么:将变量封装在 {}、"" 或 "{}"中是什么意思?我无法在网上找到关于此的任何解释 - 除了使用不会产生任何结果的符号外,我无法引用它们。 这是一个例子: declare -a gr
我需要将信息发送到我的 Html。例如 $(document).ready(function() { var = "'#"+result.tag+"'" // var = '#tag_dinamy
是否可能,如果可以,如何将以下表达式转换为一行? DEV=$(lsblk -no KNAME,MODEL | grep 'ModelNAME') DEV=${DEV%%'ModelNAME'} 简单的
isset($var) == "Test" 和 isset($var) && $var == 'Test" 有什么区别? 最佳答案 这里是一个简短的例子: $var = "Chuck Test"; v
isset($var) == "Test" 和 isset($var) && $var == 'Test" 有什么区别? 最佳答案 这里是一个简短的例子: $var = "Chuck Test"; v
如果我有一个字符串:[Object a:var b:var c:var]; 如何将 a:、b: 和 c: 与正则表达式匹配? 我试过:\[.+\s+(.+:).+\] 但它不适用于 a、b 和 c,它
这个问题在这里已经有了答案: Why does this if-statement combining assignment and an equality check return true? (
我正在 Powershell 中使用 SCSM,但遇到了 if 语句的问题。 我有一个函数,它根据作为变量传递给函数的条件收集数据。 例子: $JMLs1 = collectTickets -crit
我是一名优秀的程序员,十分优秀!