Search box in angular js

后端 未结 5 608
谎友^
谎友^ 2021-01-30 09:09

I want to implement a search box in my angularJs application. As soon as user starts typing some name in the search box , some REST service should be called and it should fetch

相关标签:
5条回答
  • 2021-01-30 09:50

    You should define a directive that listen onkeypress.

    app.directive('myOnKeyDownCall', function () {
        return function (scope, element, attrs) {
            element.bind("keydown keypress", function (event) {            
                    scope.$apply(function (){
                        scope.$eval(attrs.ngEnter);
                    });
                    event.preventDefault();
            });
        };
    });
    

    HTML

     <input type="text" my-on-key-down-call="callRestService()">   
    

    CONTROLLER

    $scope.callRestService= function() {
      $http({method: 'GET', url: '/someUrl'}).
        success(function(data, status, headers, config) {
             $scope.results.push(data);  //retrieve results and add to existing results
        })
    }
    

    Would be nice to wait until 3 keys has been typed, for that in directive:

    var numKeysPress=0;
    element.bind("keydown keypress", function (event) {   
             numKeysPress++;
                 if(numKeysPress>=3){
                    scope.$apply(function (){
                        scope.$eval(attrs.myOnKeyDownCall);
                    });
                    event.preventDefault();
                  }
            });
    

    Perhaps, exists typeahead directive from angular-ui that you can use: angular-ui typeahead I hope it helps you

    0 讨论(0)
  • 2021-01-30 09:50

    Found this to be a simplification of the accepted answer.

    // Directive
    app.directive('search', function () {
        return function ($scope, element) {
            element.bind("keyup", function (event) {
              var val = element.val();
              if(val.length > 2) {
                $scope.search(val);
              }
            });
        };
    });
    
    // In Controller
    $scope.search= function(val) {
      // fetch data
    }
    
    // HTML
    <input type="text" search>
    
    0 讨论(0)
  • 2021-01-30 10:04

    Bootstrap's "Typeahead, Asynchronous results" does exactly what you want, easily. Go to https://angular-ui.github.io/bootstrap/ then scroll down near to the bottom of the page. I used it in my CRUDiest movies database project: https://crudiest-firebase.firebaseapp.com/#/movies

    0 讨论(0)
  • 2021-01-30 10:08

    Not sure if you already solved this, but I recommend looking at this tutorial: http://angular.github.io/angular-phonecat/step-12/app/#/phones Essentially it does what you're interested in, but instead it filters out the results while typing. If you got this working, I'm interested in how you did it. I'm trying this as well.

    0 讨论(0)
  • 2021-01-30 10:09

    Why so much drama, directives, and Glyptodon blood?

    Since angular already has

    ng-keypress
    ng-keyup
    ng-keydown
    

    Use any of those to invoke REST service just as you would with ng-click.

    HTML

    <input type="search" ng-model="vm.query" ng-keyup="vm.search()" />
    

    JS

    vm.search = search;
    
    function search() {
      // Call your cool REST service and attach data to it
      vm.data = MyCoolService.myGetFunctionWhatever();
      // You can use vm.query ng-model to limit search after 2 input values for example
      //     if(vm.query.length > 2) do your magic
    };
    
    0 讨论(0)
提交回复
热议问题