【发布时间】:2014-01-05 16:04:32
【问题描述】:
我在一个简单的登录表单上有两个按钮,位于我的单页应用程序的视图/内容部分之外的标题栏的下拉列表中。表单上有两个按钮:
编辑:两个按钮都需要提交表单,但我有两种不同的结果;一个做新会员注册,另一个登录现有会员。我不想在多个部分上处理这个。
我的网站
<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() { 返回 { 限制:“A”, 链接:函数(范围,元素,属性){
element.bind("click", function(){
// when attributes.buttonId = 'join'
//call the create script
// when attributes.buttonId = 'login'
//call the authenticate script
});
}
}
});
所以我的问题只是使用ng-submit="myfunction()"can i 确定按下了哪个按钮?
【问题讨论】:
-
从切线的角度来看,这似乎是令人困惑的 UI 设计。如果我是你,我会在视觉上将这两个动作分开。
-
我正在尝试新的东西。
标签: angularjs button directive