我对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()">
中删除"#"。现在它像魅力一样发挥作用。