javascript - 如何在 Angular 过滤器中添加正则表达式

标签 javascript angularjs regex

示例:plunker

在上面的示例中,我使用 Angular 创建了一个带有过滤器选项的简单表单。

就过滤器而言,它是 Angular 提供的默认过滤器。目前,当我搜索文本“br”时,它显示 id 1 和 10。

我想在搜索输入中添加正则表达式。可以使用 regEx 完成搜索。

我需要的是,搜索项可以是

  • "br"=> 它显示了两个数据,
  • "b*"=> 显示所有以b开头的数据。
  • "*"=> 所有数据
  • "*br"=> 所有数据都以br结尾。

上述搜索应根据搜索输入显示相关数据。

scripts.js

var app = angular.module('app',[]);

app.controller('regEx', function($scope, $http) {
  $scope.init = function() {
    $http.get('https://jsonplaceholder.typicode.com/users/').success(function(data) {
      $scope.data = data;
      console.log(data);
    }).error(function(e) {
      console.log(e);
    });
  }

index.html

<!DOCTYPE html>
<html ng-app="app">

<head>
  <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.6/css/bootstrap.css">
  <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.2.4/jquery.min.js"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.5.0/angular.min.js"></script>
  <link rel="stylesheet" href="style.css" />
  <script src="script.js"></script>
</head>

<body>
  <div ng-controller="regEx" class="container">
    <h1>RegEx in Angular search</h1>
    <input type="text" class="form-control" ng-model="search" autofocus>
    <br />
    <table ng-init="init()" class="table table-bordered animated fadeIn">
      <thead>
        <tr>
          <th>Id</th>
          <th>Name</th>
          <th>Phone Number</th>
          <th>username</th>
          <th>website</th>
        </tr>
      </thead>
      <tbody>
        <tr ng-repeat="d in data | filter:search">
          <td>{{d.id}}</td>
          <td>{{d.name}}</td>
          <td>{{d.phone}}</td> 
          <td>{{d.username}}</td>
          <td>{{d.website}}</td>
        </tr>
        <tr ng-if="d.length < 1">
          <td colspan="5" class="text-center">No Router Found</td>
        </tr>
      </tbody>
    </table>
  </div>
</body>
</html>

最佳答案

在这种情况下,我可能会创建一个自定义过滤器。

这里棘手的部分是您的对象模型不是平面的,因此我们必须进行深度遍历以检查字段。这种方法的警告是您可能会检查不可见的字段(尽管我相信这是默认 Angular 过滤器的行为方式)。

如果这是一个问题,您可以调整过滤器以传入要检查的字段列表,并使用这些字段来过滤掉不需要的字段。

这是过滤器:

app.filter('wildcard', function() {

  return function(list, value) {

    if (!value) {
      return list;
    }

    var escaped = value.replace(/([.+?^=!:${}()|\[\]\/\\])/g, "\\$1");
    var formatted = escaped.replace('*', '.*')

    if (formatted.indexOf('*') === -1) {
      formatted = '.*' + formatted + '.*'
    }

    var output = []

    angular.forEach(list, function(item) {
      var regex = new RegExp('^' + formatted + '$', 'im');
      if (traverse(item, regex)) {
        output.push(item);
      }
    });

    return output
  }

  function traverse(item, regex) {
    for (var prop in item) {

      //angular property like hash
      if(prop[0] === '$$'){
        return;  
      }

      var value = item[prop];

      if (typeof value === 'object') {
        traverse(value, regex);
      }

      if(regex.test(value)){
        return true;
      }
    }
  }
})

然后在你的 html 中:

 <tr ng-repeat="d in data | wildcard:search">

Here is the plunker

关于javascript - 如何在 Angular 过滤器中添加正则表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41514450/

相关文章:

javascript - ES6 类上的自定义类数组 getter

javascript - 按类别筛选 选择

javascript - 如何在浏览器刷新时清除 session 存储,但这不应该在单击浏览器后退按钮时清除

python - 正则表达式搜索和查找

javascript - Angularjs 无法输入 Controller

javascript - 如何仅在文本溢出时显示按钮

javascript - 带有 javascript 的卡片的 RTL

javascript - grunt 未定义 - AngularJs

regex - BASH:如何将变量放入正则表达式中?

r - 开发核苷酸序列