| 
									
										
										
										
											2018-10-12 15:37:13 -04:00
										 |  |  | --- | 
					
						
							|  |  |  | title: Conditional Ternary Operators | 
					
						
							|  |  |  | --- | 
					
						
							|  |  |  | ## Conditional Ternary Operators
 | 
					
						
							|  |  |  | ### Basic usage
 | 
					
						
							|  |  |  | The ternary operator is a compact way to write an if-else inside an expression. | 
					
						
							|  |  |  | ```js | 
					
						
							| 
									
										
										
										
											2018-11-03 01:20:08 +11:00
										 |  |  | const thing = <condition> ? <if condition is true> : <if condition is false>; | 
					
						
							| 
									
										
										
										
											2018-10-12 15:37:13 -04:00
										 |  |  | ``` | 
					
						
							|  |  |  | E.g. | 
					
						
							|  |  |  | ```js | 
					
						
							|  |  |  | const cappedInput = input > 50 ? 50 : input // this will cap the input at 50 | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | ### Else if
 | 
					
						
							|  |  |  | You can also chain ternary operators, this way you will have an if-else if-else behaviour | 
					
						
							|  |  |  | ```js | 
					
						
							|  |  |  | <first condition> ? <value if first true> | 
					
						
							|  |  |  | : <second condition> ? <value if second is true> | 
					
						
							|  |  |  | : <fallback value> | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2018-11-03 01:20:08 +11:00
										 |  |  | ### Comparison to if statement:
 | 
					
						
							|  |  |  | The ternary operator is essentially a simplification of the normal `if` statement. You turn this: | 
					
						
							|  |  |  | ```js | 
					
						
							|  |  |  | if (condition) { | 
					
						
							|  |  |  |     <if condition is true>; | 
					
						
							|  |  |  | } else { | 
					
						
							|  |  |  |     <if condition is false>; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | Into this: | 
					
						
							|  |  |  | ```js | 
					
						
							|  |  |  | var output = <condition> ? <if condition is true> : <if condition is false>; | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | As you can see, it is much easier to write and read. | 
					
						
							| 
									
										
										
										
											2018-10-12 15:37:13 -04:00
										 |  |  | > **Pro tip**: As you see you can split the ternary operator on multiple lines
 | 
					
						
							|  |  |  | E.g. | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | const wealth = housesOwned > 3 ? "rich"  | 
					
						
							|  |  |  |              : housesOwned > 1 ? "nothing to complain" | 
					
						
							|  |  |  |              : "poor" | 
					
						
							|  |  |  | ``` |