javascript – 当我有多个可能的提交按钮时,如何在ENTER上执行表单提交?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – 当我有多个可能的提交按钮时,如何在ENTER上执行表单提交?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3157字,纯文字阅读大概需要5分钟。
内容图文
![javascript – 当我有多个可能的提交按钮时,如何在ENTER上执行表单提交?](/upload/InfoBanner/zyjiaocheng/804/6dac07e97bcf4b4cb090fad414c2c958.jpg)
我有一个不寻常的问题.我的表单像这样松散:
<form>
<button ng-class="{'btn-primary': ts.test.current == true}"
ng-click="$state.transitionTo('s.e.q');"
ng-show="ts.test.current && ts.test.userTestId">
View
</button>
<button ng-class="{'btn-primary': ts.test.current == true}"
ng-click="getTest(ts.test)"
ng-show="ts.test.current && !ts.test.userTestId">
Acquire
</button>
</form>
我需要的是输入键触发当前按钮主要操作.请注意,主按钮可以是两个按钮中的一个,具体取决于页面上其他项目的状态.
任何人都可以建议如何做到这一点?我看到了对ng-enter指令的引用,但如果可能的话,我认为不使用非标准指令会更好.
这是我到目前为止所尝试的.不幸的是,当我点击输入时没有任
<form ng-show="ts.test.current && ts.test.userTestId"
ng-submit="$state.transitionTo('s.e.q');">
<button ng-class="{'btn-primary': ts.test.current == true}"
type="submit">
View
</button>
</form>
<form ng-show="ts.test.current && !ts.test.userTestId"
ng-submit="getTest(ts.test)">
<button class="btn"
ng-class="{'btn-primary': ts.test.current == true}"
type="submit">
Acquire
</button>
</form>
解决方法:
从docs
You can use one of the following two ways to specify what javascript
method should be called when a form is submitted:ngSubmit directive on the form element ngClick directive on the first
button or input field of type submit (input[type=submit]) To prevent
double execution of the handler, use only one of the ngSubmit or
ngClick directives. This is because of the following form submission
rules in the HTML specification:If a form has only one input field then hitting enter in this field
triggers form submit (ngSubmit) if a form has 2+ input fields and no
buttons or input[type=submit] then hitting enter doesn’t trigger
submit if a form has one or more input fields and one or more buttons
or input[type=submit] then hitting enter in any of the input fields
will trigger the click handler on the first button or
input[type=submit] (ngClick) and a submit handler on the enclosing
form (ngSubmit)
因此,在任何给定时间,只需在表单中使用“提交”类型的一个按钮,并根据模型的状态选择该按钮.使用多个按钮,输入将触发第一个按钮上的ng-单击,类型=“提交”(它将调用ng-submit,尽管这里不需要)
不幸的是,你不能用这样的绑定修改按钮的“类型”:
<button type="{{isPrimary ? 'submit' : 'button'}}">Acquire</button>
此外,ng-show不会从DOM中删除该按钮,因此您当前的解决方案会为您留下多个type =“submit”的按钮,在这种情况下,只有第一个(隐藏或不隐藏)按钮将执行它的click功能.
如果您只想在任何给定时间看到一个按钮,那么将ng-show更改为ng-if就可以了(see this Plunk).
如果您希望两个按钮都可见,那么我可以提出的唯一解决方案是不要创建自定义按钮指令,即复制按钮块,以便根据您的条件使用不同的块(see this Plunk).
<form>
<div ng-if="ts.test.userTestId">
<button ng-class="{'btn-primary': ts.test.current == true}"
ng-click="$state.transitionTo('s.e.q');"
type="submit">
View
</button>
<button ng-class="{'btn-primary': ts.test.current == true}"
ng-click="getTest(ts.test)"
type="button">
Acquire
</button>
</div>
<div ng-if="!ts.test.userTestId">
<button ng-class="{'btn-primary': ts.test.current == true}"
ng-click="$state.transitionTo('s.e.q');"
type="button">
View
</button>
<button ng-class="{'btn-primary': ts.test.current == true}"
ng-click="getTest(ts.test)"
type="submit">
Acquire
</button>
</div>
</form>
内容总结
以上是互联网集市为您收集整理的javascript – 当我有多个可能的提交按钮时,如何在ENTER上执行表单提交?全部内容,希望文章能够帮你解决javascript – 当我有多个可能的提交按钮时,如何在ENTER上执行表单提交?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。