6

在选取数组中最小值的时候,发现如果是下面这样子的代码直接运行在<script> </script>中会有问题。

代码1

<script> 
var name=[12,3,65,8,2,12];
var min = name[0];
for (var i = 1; i <= 1; i++) {
    if (name[i]<min) 
    {
        min = name[i];
    }    
}
    console.log(min);
}
</script>

代码2

<script> 
function test(){
var name=[12,3,65,8,2,12];
var min = name[0];
for (var i = 1; i <= 1; i++) {
    if (name[i]<min) 
    {
        min = name[i];
    }    
}
    console.log(min);
}
}

test();
</script>

2段代码的结果不一样,想知道是为什么呀?

2018-11-08 提问

查看全部 6 个回答

10

已采纳

这是全局变量导致的,我们知道window在<script></script>标签里可以直接使用,其实还有很多这样的全局变量,比如:
name(默认为空)
length(默认为0)

你可能还会纳闷: 那第一种写法为什么得到的是1呢,接下来我们分析下你的代码:

<script>
    var name=[12,3,65,8,2,12]; // 全局变量
    var min = name[0];
    for (var i = 1; i <= 1; i++) {
        if (name[i]<min){
            min = name[i];
        }    
    }
    console.log(min);
</script>

// name是在全局里定义的,而name本身就是一个全局变量,而且作为全局变量时只能是字符串,无论赋值什么内容,都会调用 name.toString()方法
// 所以在for循环之前,name的值是 "12,3,65,8,2,12", 因为循环只进行了一次,所以结果是1

我们来看第二段代码:

function test(){
    var name=[12,3,65,8,2,12]; // 局部变量
    var min = name[0];
    for (var i = 1; i <= 1; i++) {
        if (name[i]<min) 
        {
            min = name[i];
        }    
    }
    console.log(min);
}
test();

// 在函数内部,name就变成了局部变量,此时可以正常赋值,即for循环之前的值是:[12,3,65,8,2,12],因为循环执行了一次, 12 < 3,所以得到的结果是3

总结:在定义变量时,最好不要使用name,因为全局下name会被转化为字符串。length是可以使用,记得还有其他的全局变量,感兴趣的话自己搜一下吧。

有帮助就点赞哦!

推广链接