AngularJs - Как написать собственный фильтр внутри директивы контроллера

Я хочу написать фильтр на массив внутри директивы контроллера с сообщением проверки. Я работаю над управлением загрузкой файлов, где пользователь может выбрать несколько файлов, когда пользователь выберет файлы, мне нужно показать все файлы в таблице с опцией удаления.

Мне нужно несколько проверок, например, чтобы показать сообщение пользователю, если пользователь выбирает уже выбранное вложение и проверки размера файла.

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

  <head>
    <meta charset="utf-8" />
    <title>AngularJS Plunker</title>
    <script>document.write('<base href="' + document.location + '" />');</script>
    <link href="style.css" rel="stylesheet" />
    <script data-semver="1.4.3" src="https://code.angularjs.org/1.4.3/angular.js" data-require="angular.js@1.4.x"></script>
    <script src="app.js"></script>
  </head>

  <body ng-controller="MainCtrl">
    <p>Hello {{name}}!</p>
    <input type="file" ng-file-model="files" multiple />
    <button type="button" ng-click="upload()">Upload</button>

    <p ng-repeat="file in files">
      {{file.name}}
      <button type="button" class="btn btn-danger btn-xs" data="{{file.name}}" ng-click="remove(file.name)">
         <span class="glyphicon glyphicon-trash">Remove</span> 
      </button>
    </p>
  </body>

</html>

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

    app.controller('MainCtrl', function($scope) {
      $scope.name = 'World';
      $scope.files = []; 
      $scope.upload=function(){
        alert($scope.files.length+" files selected ... Write your Upload Code"); 

      };
      $scope.remove=function(fileName){
        alert(fileName);
        for(var i=0;i<$scope.files.length;i++) {
                if($scope.files[i].name === fileName) {
                    $scope.files.splice(i,1);
                    break;
                }
            }
       // $scope.files.splice(0,1);
        console.log($scope.files[0]._file);
        console.log($scope.files.length);
      };
    });


   app.directive('ngFileModel', ['$parse', function ($parse) {
            return {
                restrict: 'A',
                link: function (scope, element, attrs) {
                    var model = $parse(attrs.ngFileModel);
                    var isMultiple = attrs.multiple;
                    var modelSetter = model.assign;
                    var values = [];
                    element.bind('change', function () {
                        angular.forEach(element[0].files, function (item) {
                            var value = {
                               // File Name 
                                name: item.name,
                                //File Size 
                                size: item.size,
                                //File URL to view 
                                url: URL.createObjectURL(item),
                                // File Input Value 
                                _file: item
                            };
                            values.push(value);
                        });
                        scope.$apply(function () {
                            if (isMultiple) {
                                modelSetter(scope, values);
                            } else {
                                modelSetter(scope, values[0]);
                            }
                        });
                    });
                }
            };
        }]);

В приведенном выше коде я хочу ввести фильтр для проверки дубликатов, когда я помещаю данные файла в объект файла.

Пожалуйста, направьте меня лучший способ достичь этого.

заранее спасибо

1 ответ

Я собираюсь ответить на ваш заглавный вопрос, а не на конечную цель, так как кажется, что вы просто пытаетесь получить $filter возражать в вашу директиву. Вы можете ввести это так:

app.directive('someDirectiveName',['$parse','$filter',function($parse,$filter) {
  return {
    restrict: 'A',
    link: function(scope, element, attrs) {
      $filter(filter)('yada','yada');
    }
  }
}]); 
Другие вопросы по тегам