我有一个表单,其中某处有一个提交按钮。
然而,我想以某种方式“捕捉”提交事件并防止它发生。
有什么办法能让我做到吗?
我不能修改提交按钮,因为它是自定义控件的一部分。
我有一个表单,其中某处有一个提交按钮。
然而,我想以某种方式“捕捉”提交事件并防止它发生。
有什么办法能让我做到吗?
我不能修改提交按钮,因为它是自定义控件的一部分。
当前回答
你可以像这样使用内联事件onsubmit
<form onsubmit="alert('stop submit'); return false;" >
Or
<script>
function toSubmit(){
alert('I will not submit');
return false;
}
</script>
<form onsubmit="return toSubmit();" >
Demo
在做大项目时,这可能不是一个好主意。您可能需要使用事件侦听器。
请阅读更多关于内联事件vs事件监听器(addEventListener和IE的attachEvent)在这里。因为我不能比克里斯·贝克解释得更清楚。
两者都是正确的,但没有一个是“最好的”,而且可能有 开发人员选择使用这两种方法的原因。
其他回答
以下是我的回答:
<form onsubmit="event.preventDefault();searchOrder(event);">
...
</form>
<script>
const searchOrder = e => {
e.preventDefault();
const name = e.target.name.value;
renderSearching();
return false;
}
</script>
我添加event.preventDefault();打开onsubmit,它可以工作。
你可以像这样使用内联事件onsubmit
<form onsubmit="alert('stop submit'); return false;" >
Or
<script>
function toSubmit(){
alert('I will not submit');
return false;
}
</script>
<form onsubmit="return toSubmit();" >
Demo
在做大项目时,这可能不是一个好主意。您可能需要使用事件侦听器。
请阅读更多关于内联事件vs事件监听器(addEventListener和IE的attachEvent)在这里。因为我不能比克里斯·贝克解释得更清楚。
两者都是正确的,但没有一个是“最好的”,而且可能有 开发人员选择使用这两种方法的原因。
var form = document.getElementById("idOfForm");
form.onsubmit = function() {
return false;
}
为了遵循不引人注目的JavaScript编程惯例,并取决于DOM加载的速度,使用以下代码可能是个好主意:
<form onsubmit="return false;"></form>
然后使用onload或DOM ready(如果使用库)连接事件。
$(function() { var $form = $('#my-form'); $form.removeAttr('onsubmit'); $form.submit(function(ev) { // quick validation example... $form.children('input[type="text"]').each(function(){ if($(this).val().length == 0) { alert('You are missing a field'); ev.preventDefault(); } }); }); }); label { display: block; } #my-form > input[type="text"] { background: cyan; } <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <form id="my-form" action="http://google.com" method="GET" onsubmit="return false;"> <label>Your first name</label> <input type="text" name="first-name"/> <label>Your last name</label> <input type="text" name="last-name" /> <br /> <input type="submit" /> </form>
此外,我总是使用动作属性,因为有些人可能有一些插件,如NoScript运行,然后会破坏验证。如果您正在使用action属性,至少您的用户将根据后端验证被服务器重定向。如果你使用window之类的东西。另一方面,地理位置会让事情变得糟糕。
以下是目前为止的工作(在chrome和firefox测试):
<form onsubmit="event.preventDefault(); return validateMyForm();">
其中validateMyForm()是一个函数,如果验证失败则返回false。关键是使用名称事件。我们不能使用例如e.c epreventdefault ()