使用angularjs链接标签提交表单



我对angularJS还是个新手。我一直在尝试制作一个自定义按钮,并将其附加到我的表单中,而不是使用常规按钮。我尝试了几种方法,但到目前为止,没有一种效果很好。现在,当我在输入字段中按下回车键时,我会将"结果"视图完美地加载到主页面。但当我点击搜索按钮"a"链接标签时,视图加载会立即消失。以及浏览器的位置更改为"结果",然后仅返回到"/#/"。我不知道为什么以及是什么导致了这种情况。

这是我的html:

<div id="search-container" ng-controller="SearchController">
  <form ng-submit="submitQuery()">
    <div>
      <input id="keywords" name="keywords" ng-model="query.keywords"  placeholder="please enter query" value="" required/><br>
      <a href="#" id="search-btn" ng-click="submitForm()"><img src="/Images/search-icon.png" alt="Search" title="Search" /></a>
    </div>
  </form>
</div>

这是我的模型和ngjs控制器:

var bfapp = angular.module("blogfinder", []).config(function ($routeProvider) {
  $routeProvider.when('/results', {
    templateUrl: 'PartialViews/results.html',
    controller: 'ResultsController'
  });
  $routeProvider.otherwise({ redirectTo: '/' });
});
bfapp.controller('ResultsController', function ($scope) {
});
bfapp.controller('SearchController', function ($scope, $location) {
  $scope.query = { keywords: "" };
  //on form submit
  $scope.submitQuery = function () {
    if ($scope.query.keywords !== null) {
      $location.path('/results');
    }
  };
  //on button click
  $scope.submitForm = $scope.submitQuery;
});

我觉得自己太笨了。经过几个小时的努力,我终于找到了解决办法。尽管这从未在任何网站上被提及。我所需要的只是从<a href="#" id="search-btn" ng-click="submitForm()">中删除"#"。现在它像魅力一样发挥作用。

最新更新