作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想计算特定汽车的数量并输出汽车,我可以数出萨博的数量,但是当我尝试找出 2 辆萨博汽车时,我得到的是“sa”
已更新
<!DOCTYPE html>
<html>
<body>
<script>
cars=["BMW","Volvo","Saab","Ford","Saab"];
var count=0;
var totalSuccessArray= new Array();
for (var i=0;i<cars.length;i++)
{
document.write(cars[i] + "<br>");
if(cars[i]=="Saab") {
totalSuccessArray.push(cars[i]);
count++;
}
}
alert(count);
document.write(count + "<br>");
for (var a=0;a<count;a++) {
document.write("totalssuccess"+totalSuccessArray[a] + "<br>");
}
</body>
</html>
最佳答案
在第一个 for 循环中,您设置 totalSuccessArray
至"Saab"
(cars[i]
中保存的值)。
这意味着当您引用totalSuccessArray[a]
时在第二个 for 循环中,它的值是一个字符串。字符串是字符数组,因此第二个 for 循环的作用是输出 "Saab"
的前两个元素。即字符 "S"
和"a"
.
您需要更改线路
totalSuccessArray = cars[i];
至
totalSuccessArray.push(cars[i]);
这样您就可以将值“Saab”添加到现有的 totalSuccessArray
中数组。
除此之外,您还应该移动 totalSuccessArray
的声明到代码顶部,for 循环之外。
您还可以对此代码进行许多其他优化,但这超出了特定问题的范围。
关于javascript - 如何根据一定的条件输出元素的个数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13825576/
我正在尝试开发右边框/Angular 具有特定 Angular (30°) 的表格。我见过一些类似的解决方案,但它们都无法在一定程度上发挥作用。如果我想从 30° 改变到 20°,我不想花太多力气。
我是一名优秀的程序员,十分优秀!