Pure JS to lodash

Pure JS to lodash

本文关键字:lodash to JS Pure      更新时间:2023-09-26

我这里有一些不同的语句,希望您告诉我它们是否等效:

myApp.filter('myFilter', function() {
  var result, i, sport, y, contains, league;
  return function(sports, filterBy) {    
    if (angular.isUndefined(sports) || !filterBy) {
      return sports;
    }
    filterBy = filterBy.toLowerCase();
    result = [],
    contains = function(haystack, needle) {
      return haystack.toLowerCase().indexOf(needle) > -1;
    };
    for (i = 0; i < sports.length; i++) {
      sport = sports[i];
      if (contains(sport.name, filterBy)) {
        result.push(sport);
        continue;
      } else {
        for (y = 0; y < sport.leagues.length; y++) {
          league = sport.leagues[y];
          if (contains(league.name, filterBy)) {
            result.push(sport);
            break;
          }
        }
      }
    }
    return result;
  };
});

现在使用lodash:

myApp.filter('myFilter', function() {
  var result, i, sport, y, contains, league;
  return function(sports, filterBy) {    
    if (angular.isUndefined(sports) || !filterBy) {
      return sports;
    }
    filterBy = filterBy.toLowerCase();
    result = [],
    contains = function(haystack, needle) {
      return haystack.toLowerCase().indexOf(needle) > -1;
    };
  _.each(sports.length, function(sport) {
      if (contains(sport.name, filterBy)) {
        result.push(sport);
        continue;
      } else {
        _.each(sport.leagues.length, function(league) {
          if(contains(league.name, filterBy)) {
            result.push(sport);
            break;
          }
        });
      }
    });

只是我试图理解洛达什的逻辑。我在几乎纯JS中有这个功能,但一旦我试图将其翻译成lodash,我的应用程序就会崩溃,所以我想知道错误在哪里?

这里我有一个带有纯js函数的Plnkr,在库部分,你会看到我有underscore,因为我不知道为什么lodash没有加载,所以,我所做的只是:使用_.each而不是for loop 将该函数转换为lodash函数

在这种情况下,您不会使用"each"。此外,在"each"中,你不会得到"continue"或"break"。对我来说,我会使用"过滤器"来获得过滤后的结果。所以代码应该是这样的:

var result = sports.filter(function(sport){
  return (
      contains(sport.name, filterBy) 
    || (
      sport.leagues && sport.leagues.some(function(league) { 
        return contains(league.name, filterBy) 
      })
    )
  )
})

或用于lodash/下划线

var result = _.filter(sports, function(sport) {
  return (
      contains(sport.name, filterBy) 
    || (
      sport.leagues && _.some(sport.leagues, function(league) { 
        return contains(league.name, filterBy);
      })
    )
  )
});