У меня есть две кнопки в простой форме входа в раскрывающемся списке на панели заголовка, которая находится за пределами части представления/контента моего одностраничного приложения. На форме есть две кнопки:
EDIT: обе кнопки должны отправить форму, но у меня есть два разных результата; один регистрирует новых участников, другой входит в систему существующих участников. Я не хочу обрабатывать это на нескольких частях.
Мой сайт
<div class="collapse navbar-collapse">
<ul class="nav navbar-nav navbar-right">
<li class="active">
<a href="#/home">Home</a>
</li>
<li class="divider-vertical"></li>
<li>
<div class="btn-group btn-group-xs navbar-btn btn-pad">
<a href="#" class="btn navbar-btn btn-default">NL</a>
<a href="#" class="btn navbar-btn btn-default">FR</a>
<a href="#" class="btn navbar-btn btn-default">EN</a>
</div>
</li>
<li class="divider-vertical"></li>
<!-- Begin Login Section -->
<li class="dropdown">
<a class="dropdown-toggle" href="#" data-toggle="dropdown">Signup/Login <strong class="caret"></strong></a>
<div class="dropdown-menu">
<div class="accountForm">
<!--form action="#" method="post" role="form"-->
<form name="loginForm" ng-submit="login()" ng-controller="homeController">
<div class="form-group">
<label class="control-label" for="username">Username</label>
<input type="text" ng-model="credentials.username" name="username" class="form-control input-sm" placeholder="username" required/>
</div>
<div class="form-group">
<label class="control-label" for="password">Password</label>
<input type="password" ng-model="credentials.password" name="password" class="form-control input-sm" placeholder="password" required/>
</div>
<div class="form-group">
<label class="control-label" for="remember">
<input type="checkbox" class"form-control" name="remember" value="1"/>Remember me</label>
</div>
<div class="form-group btn-group-justified">
<div class="btn-group">
<button button-id="join" type="submit" class="btn btn-default">New? Join us</button>
<input type="hidden" class="btn" />
</div>
<div class="btn-group inline">
<input type="hidden" class="btn" />
<button button-id="login" type="submit" class="btn btn-primary active">Log in</button>
</div>
</div>
</form>
</div>
</div>
</li>
<!-- End Login Section -->
</ul>
</div>
<!--/.nav-collapse -->
</div>
</div>
<div id="page" ng-view>
Первая кнопка предназначена для отправки пользователя в процесс входа в систему (если он уже зарегистрирован), а вторая кнопка предназначена для регистрации новых пользователей.
У меня проблема в том, что если я использую директиву <form ng-submit="myFunction()">
, я еще не нашел способ определить нажатую кнопку.
В качестве альтернативы я могу создать свою собственную директиву, в которой я могу определить, какая кнопка была нажата, но по сравнению с этим кажется, что это требует больших усилий по кодированию, и действительно ли это способ Angular?
app.directive ('buttonId', function () { return { ограничить: «A», ссылка: функция (область, элемент, атрибуты) {
element.bind("click", function(){
// when attributes.buttonId = 'join'
//call the create script
// when attributes.buttonId = 'login'
//call the authenticate script
});
}
}
});
Итак, мой вопрос просто с помощью ng-submit="myfunction()"
можно ли определить, какая кнопка была нажата?