欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

浅说JavaScript 中 label 标签的使用

程序员文章站 2022-03-26 18:37:42
...

最近再看《JavaScript高级程序设计》发现一个label语句标签的使用,主要使用在for循环语句中,和break以及continue一起使用;合理使用语句可以大幅降低程序性能。

let num =0;
for (let i=0;i<10;i++){
    for (let j=0;j<10;j++){
        if (i==5&&j==5){
            console.log(num);//55
            break;
        }
        num++;
    }
}
console.log(num);//95

这是一段没有使用label语句标签的嵌套循环;可以看到我们需要在条件i、j均为5的时候输出我们想要的结果,这个时候程序执行了55次,也就是num的值;按照设想我们就应该在这个时候结束整个循环。但是外层num的输出是95,这就说明了在到达符合条件的时候内层循环已经跳出,但是外层循环没有跳出,这个也就是为什么外层num的结果为95的原因。

let num =0;
start:
for (let i=0;i<10;i++){
    for (let j=0;j<10;j++){
        if (i==5&&j==5){
            console.log(num);//55
            break start;
        }
        num++;
    }
}
console.log(num);//55

添加 start 标签之后,start 标签表示最外层循环;这样给break语句添加标签之后循环到达退出条件就会退出内部循环同时退出外部循环,这就减少了没有加标签时候仅退出内部循环外部循环继续作用带来的性能负荷。

虽然label可以很好执行复杂的操作,但是过多的使用也会让调试的难度增加。