124 lines
7.0 KiB
Markdown
124 lines
7.0 KiB
Markdown
|
---
|
||
|
title: Spinal Tap Case
|
||
|
---
|
||
|
 Remember to use <a>**`Read-Search-Ask`**</a> if you get stuck. Try to pair program  and write your own code 
|
||
|
|
||
|
###  Problem Explanation:
|
||
|
|
||
|
Convert the given string to a lowercase sentence with words joined by dashes.
|
||
|
|
||
|
#### Relevant Links
|
||
|
|
||
|
* <a href='https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String' target='_blank' rel='nofollow'>String global object</a>
|
||
|
* <a>JS Regex Resources</a>
|
||
|
* <a href='http://forum.freecodecamp.com/t/javascript-string-prototype-replace/15942' target='_blank' rel='nofollow'>JS String Prototype Replace</a>
|
||
|
* <a href='http://forum.freecodecamp.com/t/javascript-string-prototype-tolowercase/15948' target='_blank' rel='nofollow'>JS String Prototype ToLowerCase</a>
|
||
|
|
||
|
##  Hint: 1
|
||
|
|
||
|
Create a regular expression for all white spaces and underscores.
|
||
|
|
||
|
> _try to solve the problem now_
|
||
|
|
||
|
##  Hint: 2
|
||
|
|
||
|
You will also have to make everything lowercase.
|
||
|
|
||
|
> _try to solve the problem now_
|
||
|
|
||
|
##  Hint: 3
|
||
|
|
||
|
The tricky part is getting the regular expression part to work, once you do that then just turn the uppercase to lowercase and replace spaces with underscores using `replace()`.
|
||
|
|
||
|
> _try to solve the problem now_
|
||
|
|
||
|
## Spoiler Alert!
|
||
|
|
||
|

|
||
|
|
||
|
**Solution ahead!**
|
||
|
|
||
|
##  Basic Code Solution:
|
||
|
|
||
|
function spinalCase(str) {
|
||
|
// Create a variable for the white space and underscores.
|
||
|
var regex = /\s+|_+/g;
|
||
|
|
||
|
// Replace low-upper case to low-space-uppercase
|
||
|
str = str.replace(/([a-z])([A-Z])/g, '$1 $2');
|
||
|
|
||
|
// Replace space and underscore with -
|
||
|
return str.replace(regex, '-').toLowerCase();
|
||
|
}
|
||
|
|
||
|
// test here
|
||
|
spinalCase('This Is Spinal Tap');
|
||
|
|
||
|
 <a href='https://repl.it/CLnS/0' target='_blank' rel='nofollow'>Run Code</a>
|
||
|
|
||
|
### Code Explanation:
|
||
|
|
||
|
* **regex** contains the regular expression `/\s+|_+/g`, which will select all white spaces and underscores.
|
||
|
* The first `replace()` puts a space before any encountered uppercase characters in the string **str** so that the spaces can be replaced by dashes later on.
|
||
|
* While returning the string, another `replace()` replaces spaces and underscores with dashes using **regex**.
|
||
|
|
||
|
##  Intermediate Code Solution:
|
||
|
|
||
|
function spinalCase(str) {
|
||
|
// Replace low-upper case to low-space-uppercase
|
||
|
str = str.replace(/([a-z])([A-Z])/g, '$1 $2');
|
||
|
// Split on whitespace and underscores and join with dash
|
||
|
return str.toLowerCase().split(/(?:_| )+/) .join('-');
|
||
|
}
|
||
|
|
||
|
// test here
|
||
|
spinalCase('This Is Spinal Tap');
|
||
|
|
||
|
 <a href='https://repl.it/CLnT/0' target='_blank' rel='nofollow'>Run Code</a>
|
||
|
|
||
|
### Code Explanation:
|
||
|
|
||
|
* Similar to the first solution, the first `replace()` puts a space before any encountered uppercase characters in the string **str** so that the spaces can be replaced by dashes later on.
|
||
|
* Instead of using `replace()` here to replace whitespace and underscores with dashes, the string is `split()` on the regular expression `/(?:_| )+/` and `join()`-ed on `-`.
|
||
|
|
||
|
#### Relevant Links
|
||
|
|
||
|
* <a href='http://forum.freecodecamp.com/t/javascript-string-prototype-split/15944' target='_blank' rel='nofollow'>JS String Prototype Split</a>
|
||
|
* <a href='http://forum.freecodecamp.com/t/javascript-array-prototype-join/14292' target='_blank' rel='nofollow'>JS Array Prototype Join</a>
|
||
|
|
||
|
##  Advanced Code Solution:
|
||
|
|
||
|
function spinalCase(str) {
|
||
|
// "It's such a fine line between stupid, and clever."
|
||
|
// --David St. Hubbins
|
||
|
|
||
|
return str.split(/\s|_|(?=[A-Z])/).join('-').toLowerCase()
|
||
|
}
|
||
|
|
||
|
 <a href='https://repl.it/EUZV' target='_blank' rel='nofollow'>Run Code</a>
|
||
|
|
||
|
### Code Explanation:
|
||
|
|
||
|
* Split the string at one of the following conditions (_converted to an array_)
|
||
|
* a whitespace character [`\s`] is encountered
|
||
|
* underscore character [`_`] is encountered
|
||
|
* or is followed by an uppercase letter [`(?=[A-Z])`]
|
||
|
* Join the array using a hyphen (`-`)
|
||
|
* Lowercase the whole resulting string
|
||
|
|
||
|
#### Relevant Links
|
||
|
|
||
|
* <a href='http://devdocs.io/javascript/global_objects/string/split' target='_blank' rel='nofollow'>String#split</a>
|
||
|
* <a href='http://devdocs.io/javascript/global_objects/regexp' target='_blank' rel='nofollow'>RegExp</a>
|
||
|
* <a href='http://devdocs.io/javascript/global_objects/array/join' target='_blank' rel='nofollow'>Arrray#join</a>
|
||
|
* <a href='http://devdocs.io/javascript/global_objects/string/tolowercase' target='_blank' rel='nofollow'>String#toLowerCase</a>
|
||
|
|
||
|
##  NOTES FOR CONTRIBUTIONS:
|
||
|
|
||
|
*  **DO NOT** add solutions that are similar to any existing solutions. If you think it is **_similar but better_**, then try to merge (or replace) the existing similar solution.
|
||
|
* Add an explanation of your solution.
|
||
|
* Categorize the solution in one of the following categories — **Basic**, **Intermediate** and **Advanced**. 
|
||
|
* Please add your username only if you have added any **relevant main contents**. ( **_DO NOT_** _remove any existing usernames_)
|
||
|
|
||
|
> See  <a href='http://forum.freecodecamp.com/t/algorithm-article-template/14272' target='_blank' rel='nofollow'>**`Wiki Challenge Solution Template`**</a> for reference.
|