Is using the break statement bad practice?

In JavaScript, is returning out of a switch statement considered a better practice than using break?

  • Option 1 - switch using return: function myFunction(opt) { switch (opt) { case 1: return "One"; case 2: return "Two"; case 3: return "Three"; default: return ""; } } Option 2 - switch using break: function myFunction(opt) { var retVal = ""; switch (opt) { case 1: retVal = "One"; break; case 2: retVal = "Two"; break; case 3: retVal = "Three"; break; } return retVal; } I know that both work, but is one more of a best practice? I tend to like Option 1 - switch using return best, as it's cleaner and simpler. http://jsfiddle.net/DotNetScott/NENjc/: var SFAIC = {}; SFAIC.common = { masterPages: { cs: "CS_", cp: "CP_" }, contentPages: { cs: "CSContent_", cp: "CPContent_" } }; function getElementPrefix(page) { return (page in SFAIC.common.masterPages) ? SFAIC.common.masterPages[page] : (page in SFAIC.common.contentPages) ? SFAIC.common.contentPages[page] : undefined; } To call the function, I would do so in the following ways: getElementPrefix(SFAIC.common.masterPages.cs); getElementPrefix(SFAIC.common.masterPages.cp); getElementPrefix(SFAIC.common.contentPages.cs); getElementPrefix(SFAIC.common.contentPages.cp); Problem here is that it always returns undefined. I'm guessing that it's because it's passing in the actual value of the object literal and not the property. What would I do to fix this using the technique described in @ic3b3rg's comments?

  • Answer:

    A break will allow you continue processing in the function. Just returning out of the switch is fine if that's all you want to do in the function.

Scott at Stack Overflow Visit the source

Was this solution helpful to you?

Other answers

It depends, if your function only consists of the switch statement, then I think that its fine. However, if you want to perform any other operations within that function, its probably not a great idea. You also may have to consider your requirements right now versus in the future. If you want to change your function from option one to option two, more refactoring will be needed. However, given that within if/else statements it is best practice to do the following: var foo = "bar"; if(foo == "bar") { return 0; } else { return 100; } Based on this, the argument could be made that option one is better practice. In short, there's no clear answer, so as long as your code adheres to a consistent, readable, maintainable standard - that is to say don't mix and match options one and two throughout your application, that is the best practice you should be following.

Mark Costello

Just Added Q & A:

Find solution

For every problem there is a solution! Proved by Solucija.

  • Got an issue and looking for advice?

  • Ask Solucija to search every corner of the Web for help.

  • Get workable solutions and helpful tips in a moment.

Just ask Solucija about an issue you face and immediately get a list of ready solutions, answers and tips from other Internet users. We always provide the most suitable and complete answer to your question at the top, along with a few good alternatives below.