- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我经常遇到一种情况,我会根据自己的心情行事:
情况A):
function a() {
var msg = 'a()';
..operate on msg
}
function b() {
var msg = 'b()';
..operate on msg
}
情况 B):
var msg;
function a() {
msg = 'a()';
..operate on msg
}
function b() {
msg = 'b()';
..operate on msg
}
请注意,“对消息进行操作” 我指的不是函数,而是一堆操作。
我对此很感兴趣,因为 JSHint 指出变量已经预定义,尽管它们具有相同的名称但出现在不同的函数中。
更新:我问这个的时候可能是不正确的,所以为了澄清我已经改变了功能的情况。
更新 2我了解范围。我的意思是,除了范围之外,还有其他优势吗?
最佳答案
正如其他人所建议的,您必须阅读更多有关 Javascript 中的变量提升的信息。我将尝试演示它。
function test() {
var t1 = msg + " hello";
console.log(t1); // prints "undefined hello" because msg is undefined
var t2 = msgx + " hello"; // msgx ReferenceError
var a = 1;
var b = 2;
if (a > b) {
var msg = 'sample';
}
}
test();
在示例中,您可以看到声明了 msg
。但它是未定义的。另一方面,msgx
会导致引用错误。它没有在任何地方声明。所以重点是语句 var msg = 'sample';
后面的函数中 if
大括号使 msg
成为一个有效的变量功能。所以再次声明 msg
会给你预定义的变量警告。
在 javascript 中只有一个函数可以创建一个作用域。即使有其他控制语句的内括号,函数中声明的所有内容都将在整个函数范围内可用。所有在函数内不同行中声明的变量都将被提升并视为在函数的起始行中声明。
关于javascript - 在全局范围内预定义变量有什么优点?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16834887/
我对我接管的项目有疑问。我正在转换其他人编写的 MS Access 应用程序并将其转换为 MySQL/PHP Web 应用程序。其中大部分已经完成,但是,当涉及到此应用程序的调度部分时,我处于停滞状态
我有一个带有 @Scheduled 注释的方法。此方法包含长时间运行、昂贵的操作。我担心当计划的方法开始运行时应用程序会变慢。有什么办法可以为预定方法分配优先级吗?在 Spring 中启动低优先级后台
我的大学有一个预订项目房间的网站;但除非你很幸运或者半夜醒着,否则要订到房间并不容易。因此,我编写了一个 JS 片段来填写所有必要的字段并提交表单。 但是我如何自动化这个过程呢? 我的目的基本上是加载
我正在评估处理大量排队消息的可能解决方案,这些消息必须在特定日期和时间交付给工作人员。执行它们的结果主要是对存储数据的更新,它们最初可能是也可能不是由用户操作触发的。 例如,想想你在一个假设的大型星际
@Scheduled documentation here声明 fixedRateString值可以是 the delay in milliseconds as a String value, e.g
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 4年前关闭。 Improve t
我有一个有趣的情况。我解析了几个新闻发布网站,想通过调度程序将它们保存到数据库中。但是保存时出现错误。由于交易后写条件 described here . 我的模型类是 @Entity @Table(n
我正在阅读 Java Concurrency in Practice 并遇到以下代码片段。 public static void timedRun(final Runnable r,
使用 Azure 数据工厂,是否可以对驻留在 Azure SQL 数据库中的多个(不是全部)表中的所有行执行预定的 1:1 复制/克隆到另一个 Azure SQL 数据库(在本例中为 Azure SQ
我是一名优秀的程序员,十分优秀!