JavaScript 开关奇怪的行为

JavaScript switch strange behavior(JavaScript 开关奇怪的行为)
本文介绍了JavaScript 开关奇怪的行为的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有以下代码片段.

var caseObj = function () {

}

switch (typeof caseObj) {

    case "function":
        console.log("it is function");

    case "object":

        console.log("It is object now");
}

它的输出是

it is function.
It is object now.

typeof caseObj 给出输出 function 但它仍然评估case "object" 也是case.

But typeof caseObj gives output function but it still evalutes case "object" case also.

这怎么可能?我做错了什么吗?

How it is possible? Am I doing wrong anythig?

typeof caseObj 是给 function,所以它执行那个 case 但它也执行 object 案例.为什么会出现这种奇怪的行为?

typeof caseObj is giving function,So it executing that case but it also executing object case.Why this strange behavior?

推荐答案

问题不在于typeof,而是你错过了案例中的break语句.这将使 casefunction OR object 并执行这两种情况的块.

The problem is not with the typeof, but you've missed the break statement in the case. That'll make the case like function OR object and execute the block of both the cases.

您错过了 break;case 的 语句.这就是在下一个case中失败的原因.

You missed the break; statement for the cases. This is the reason, of falling out in the next case.

break 语句终止当前循环、switch 或标号语句,并将程序控制转移到终止语句之后的语句.

The break statement terminates the current loop, switch, or label statement and transfers program control to the statement following the terminated statement.

var caseObj = function() {

}

switch (typeof caseObj) {

  case "function":
    document.write("it is function");
    break;

  case "object":

    document.write("It is object now");
    break;
}

来自答案中的评论:

但是如果没有匹配的case并退出switch,它也会崩溃.但是它也会执行caseobject":语句.为什么?

来自 MDN

如果找到匹配项,程序将执行相关的语句.如果多个案例与提供的值匹配,则选择第一个匹配的案例,即使案例彼此不相等.

If a match is found, the program executes the associated statements. If multiple cases match the provided value, the first case that matches is selected, even if the cases are not equal to each other.

与每个 case 标签关联的可选 break 语句确保程序在执行匹配的语句后跳出 switch,并在 switch 后面的语句处继续执行.如果省略了break,程序将继续执行switch语句中的下一条语句.

The optional break statement associated with each case label ensures that the program breaks out of switch once the matched statement is executed and continues execution at the statement following switch. If break is omitted, the program continues execution at the next statement in the switch statement.

这篇关于JavaScript 开关奇怪的行为的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Update another component when Formik form changes(当Formik表单更改时更新另一个组件)
Formik validation isSubmitting / isValidating not getting set to true(Formik验证正在提交/isValiating未设置为True)
React Validation Max Range Using Formik(使用Formik的Reaction验证最大范围)
Validation using Yup to check string or number length(使用YUP检查字符串或数字长度的验证)
Updating initialValues prop on Formik Form does not update input value(更新Formik表单上的初始值属性不会更新输入值)
password validation with yup and formik(使用YUP和Formick进行密码验证)