I am attempting to take a given string and replace a given number in that string with a character. Specifically:
- 5 is to be replaced with "S"
- 1 is to be replaced with "I"
- 0 is to be replaced with "O"
(this is a Kata exercise)
I have written a function which should:
- Take the string and convert it into an array
- Loop over the array
- Replace each instance of the aforementioned numbers with the appropriate replacements using .replace()
- Return the joined string.
My code is as appears below
Function correct(string) {
let array = string.split('')
for (let i = 0; i < array.length; i ) {
array[i].replace('5', 'S')
array[i].replace('0', 'O')
array[i].replace('1', 'I')
}
return array.join('');
}
The function returns the string exactly as initially provided, unchanged. I suspect my issue is with the way I've used the .replace()
method within the loop, or the index positions declared.
CodePudding user response:
String.prototype.replace
returns a new string and does not mutate the variable it was executed on.
That's why you need to assign the result of replacement somewhere.
To fix your code just do the following with each replacement:
array[i] = array[i].replace('5', 'S');
Note 1: since array[i]
is always a single character, there is no need in replace
, because you can just compare like so:
if (array[i] === '5') {
array[i] = 'S';
}
or oneliner:
array[i] = array[i] === '5' ? 'S' : array[i];
Note 2: for
loop for a replacement is not a clean code. JavaScript is very flexible and provides much better solutions to the problem. Eg. String.prototype.replaceAll
.
CodePudding user response:
You can do with simple replace()
like this, Note: regarding why your version does not work, just see the above comments.
const key_to_replace = {
'5': 'S',
'1': 'I',
'0': 'O'
}
const correct = (str) =>
str.replace(/./g, (m) => key_to_replace[m] ?? m);
console.log(correct("this 5is a0 test1 with 55abc"))
CodePudding user response:
Try this :
const inputStr = 'AB5DE0G1H';
function correct(string) {
return string.replaceAll('5', 'S').replaceAll('0', 'O').replaceAll('1', 'l')
}
console.log(correct(inputStr));