Javascript map method on array of string elements

后端 未结 8 457
悲哀的现实
悲哀的现实 2021-01-11 10:09

I am trying to understand how to implement the map method (rather than using a for loop) to check a string for palindromes and return boolean values for whether the mapped a

相关标签:
8条回答
  • 2021-01-11 11:09

    The map method will literally 'map' a function call onto each element in the array, take this as a simple example of increasing the value of each integer in an array by 1:

    var items = [1,2,3];
    items.map(function(item) { 
      return item + 1;
    });
    
    // returns [2,3,4]
    

    In your case, you are trying to use map to accept or reject a string if it's a palindrome, so a simple implementation might be:

    var items = ['mum', 'dad', 'brother'];
    items.map(function(item) {
      return item.split('').reverse().join('') === item;
    });
    
    // returns [true, true, false]
    

    I'm not 100% sure of your reasons for using map, because if you were trying to just filter the array and remove the strings that aren't palindromes, you should probably use the filter method instead, which works in the same way, but would remove any that return false:

    var items = ['mum', 'dad', 'brother'];
    items.filter(function(item) {
      return item.split('').reverse().join('') === item;
    });
    
    // returns ['mum', dad']
    

    In your case you are splitting a string first to get your array of characters; you may also want to make that string lower case and remove punctuation, so an implementation might be:

    var string = 'I live at home with my Mum, my Dad and my Brother!';
    var items = string.toLowerCase().replace(/[^a-z0-9-\s]+/, '').split(' ');
    items.filter(function(item) {
      return item.split('').reverse().join('') === item;
    });
    
    // returns ['i', 'mum', dad']
    

    As mentioned in one of the comments on your question, you need to ensure you return a value from your function if you are using a separate function to perform the check, so this is how your function should look:

    function checkPalindromes(string) {
      var items = string.toLowerCase().replace(/[^a-z0-9-\s]+/, '').split(' ');
      items.filter(function(item) {
        return item.split('').reverse().join('') === item;
      });
    
      return items;
    }
    

    And you would call it using:

    checkPalindromes('I live at home with my Mum, my Dad and my Brother!'); // ['i', 'mum', 'dad']
    
    0 讨论(0)
  • 2021-01-11 11:13

    The map function in javascript (and pretty much in any language) is a great little function that allows you to call a function on each of the items on a list, and thus changing the list itself. The (anonymous) function you're passing as an argument accepts an argument itself, which is filled by an item of the list it is working on, each time it is called.

    So for a list [1,2,3,4], the function function(item) { return item + 1 }, would give you a list of [2,3,4,5] for a result. The function you passed to $.map() is run over each element of the list, and thus changing the list.

    So for your code: in the function you're passing as an argument to $.map(), you're returning whether the old and new array are equal (which is false btw). So since you're returning a boolean value, the list you'll end up with is a list of bools. What I think you want to do, is extract the newArray == myArray from the function you're passing to $.map(), and putting it after your $.map() call. Then inside the function you're passing to $.map(), return the item you're splitting and whatnot, so your newArray will be an array of strings like myArray.

    0 讨论(0)
提交回复
热议问题