我在单页面应用程序的视图/内容部分之外的标题栏上的下拉列表中有一个简单登录表单上的两个按钮。表单上有两个按钮:Angular.js确定哪个按钮导致提交的最佳方法是什么?
编辑:两个按钮都需要提交表单,但我有两个不同的结果;一个是新会员注册,另一个是现有会员。我不想在多个部分处理这个问题。
我的主页
<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()">
指令,我还没有找到一种方法来确定按下按钮。
我也可以创建自己的指令,在那里我可以确定被按下的按钮,但这似乎是相当多的编码工作,而且这真的是角度的方式吗?
app.directive( 'buttonId',函数(){ 回报{ 限制: “A”, 链接:功能(范围,元素,属性){
element.bind("click", function(){
// when attributes.buttonId = 'join'
//call the create script
// when attributes.buttonId = 'login'
//call the authenticate script
});
}
}
});
所以我的问题是根本使用ng-submit="myfunction()"
我可以判断哪个按钮被按下?
正切地说,这看起来像是令人困惑的UI设计。如果我是你,我会在视觉上将这两种行为分开。 – jessegavin
我在尝试新的东西。 – T9b