首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >javascript: if情况下的主要放缓

javascript: if情况下的主要放缓
EN

Stack Overflow用户
提问于 2014-10-21 09:56:03
回答 2查看 28关注 0票数 1

我有一个非常简单的代码来生成一个表。

然而,当我添加了3行if,它变得非常慢。有人知道为什么吗?

代码:

代码语言:javascript
复制
for (var i=0; i<=noofRows; i++){
  var rg = genguid();
  for (var j=1; j<=noofbackuprows; j++){
  to+='<tr>';
  to+='<td>'  + prefix + rg + '-' + j;      
  to+='</td>';      
  if (j<3){var vval = 10000};
  if (j=3){var vval = 5000};
  if (j>4){var vval = 2500};
  to+='<td>'  + vval + '</td>';          
  to+='</tr>';      
    }
}

侵权线路:

代码语言:javascript
复制
  if (j<3){var vval = 10000};
  if (j=3){var vval = 5000};
  if (j>4){var vval = 2500};

如果我移除侵权线,效果会很好。到底怎么回事?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-10-21 09:58:53

关于您目前的情况,有两个问题:

代码语言:javascript
复制
if (j<3){var vval = 10000};
if (j=3){var vval = 5000};
if (j>4){var vval = 2500};

首先,j = 33值赋值给j。它不检查j是否等于3。若要修复此问题,请将其更改为=====

代码语言:javascript
复制
if (j === 3) { var vval = 5000; }

这就是为什么您的应用程序变得缓慢的原因,因为您的for循环被卡在一个循环中,因为在某个点之后,j总是等于3

其次,您应该使用else if,否则将检查所有三个if语句,即使第一个符合要求:

代码语言:javascript
复制
if (j < 3) { var vval = 10000 }
else if (j === 3) { var vval = 5000 }
else if (j > 4) { var vval = 2500 }

还请注意,在if语句的花括号后面加上分号是不必要的,所以我也删除了它们。

票数 3
EN

Stack Overflow用户

发布于 2014-10-21 09:59:28

原因是因为在循环中,您将j=3设置为永久。我很惊讶这不会使浏览器完全崩溃。

使用相等运算符==或严格相等运算符===

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26483855

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档