JS 基础:双for循环,打印正的三角形带星号,浏览器崩掉
本帖最后由 clearwater 于 2020-2-11 20:36 编辑1、由于能量有限,所以我只给前两位,回答正确,并且能帮我理解的大神评分。后面的人的答案如果雷同,我只能在此表示感谢了。请恕不一一评分了。(明天再补评分。)
2、请口下留情,不要来讥讽我;另外不要来回答与我的问题无关的水帖。比如:感谢分享,路过,帮顶,我也不懂。
我想做一个正的三解形,带米字号。可是我写的代码,想打开chrome运行,网页都崩掉了,所以我也不用能调试工具来检查到底代码哪里出现问题了。我用别的写得对的代码,能正常打开,chrome也没崩,所以我估计是下面这些代码有问题。
大神能不能帮我看看哪里出现问题了? ---我想知道chrome 为什么崩了,不是如何写出正确的代码,三角形。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script>
var str = ''; //注意这里要写空字符,str = ''; 不要写0,否则0会打出来的。
for (var i = 1; i <= 10; i++) {
for (var j = 10; j <= 10; j--) {
str = str + '*';
}
str = str + '\n';
}
console.log(str);
</script>
</head>
<body>
</body>
</html>
本帖最后由 tuziang 于 2020-2-11 20:32 编辑
var j = 10; j <= 10; j--
改成
var j = 1; j <= i; j++
崩掉是因为j--导致for死循环 tuziang 发表于 2020-2-11 20:29
var j = 10; j
谢谢回复。
j++ 程序就停了,不是吗?
我要每一行,递减。 clearwater 发表于 2020-2-11 20:32
谢谢回复。
j++ 程序就停了,不是吗?
改过来了 for (var j = 10; j <= 10; j--) {
j可以为负数。。。就崩了 for (var j = 10; j <= 10; j--) {
str = str + '*';
}
这里j是一直小于10的,所以会一直运行,直到内存占满,浏览器崩溃 ZipayYu 发表于 2020-2-11 20:35
for (var j = 10; j
谢谢楼中三位大神的帮助。
@tuziang
@ZipayYu
等明天有能量,各给一个热心值。
另一位大神,也谢谢,不过我没看明白,由于能量有限,所以就不评分了。 我真是太蠢了。正三角,根本不需要用双for
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script>
var str = ''; //注意这里要写空字符,str = ''; 不要写0,否则0会打出来的。
for (var j = 1; j <= 10; j++) {
str = str + '*';
console.log(str);
}
</script>
</head>
<body>
</body>
</html>
页:
[1]