表单验证提交——submit与button
之前做东西接触过表单验证提交,但是都是为了完成工作,做完就做完了,没有注过表单验证提交有几种方法,各方法都有啥区别。今天瞎折腾了一下,对他们研究了一下,如下是我个人的理解:
submit:
从字面上看是“提交”的意思,专门为提交而生。他既可以接受点击提交表单也能接受Enter(回车键)提交表单(也就是表单里的控件在获取焦点的时候回车直接提交表单),这样就比较人性化。
<form name="myForm" action="http://www.baidu.com" method="get" >
name:<input name="name" type="text" /><br />
<input name="submit" type="submit" value="submit提交" />
</form>
当我输入"xiaomou"回车的时候表单提交了,url为:http://www.baidu.com/?name=xiaomou&submit=submit提交
button:
就是个普通的按钮,接受回车提交表单,但是点击它的时候没反应(当然我说的是没有js的情况下),如要他实现简单的提交表单,要通过表单提交事件,<input name="button" type="button" value="button提交" onClick="this.form.submit()"/>,这时候你会惊奇的发现它也能像submit按钮一样点击就可以提交表单了
<form name="myForm" action="http://www.baidu.com" method="get" >
name:<input name="name" type="text" /><br />
<input name="button" type="button" value="button提交" onClick="this.form.submit()"/>
</form>
同样当我输入"xiaomou"回车的时候表单提交了,url为:http://www.baidu.com/?name=xiaomou,没有了submit=submit提交
下面通过测试代码比较一下他们表单验证提交的不同实现方法:
通过submit按钮触发表单的提交事件onSubmit来提交表单
<form name="myForm" action="http://www.baidu.com" method="get" onSubmit="return submitForm()" >
name:<input name="name" type="text" /><br />
<input name="submit" type="submit" value="submit提交"/>
</form>
<script>
function submitForm(){
var _form=document.forms[0];
//var _form=document.getElementsByName("myForm")[0];
//var _form=document.getElementsByName("myForm").item(0);
return checkName(_form.name,_form.name.value);
}
function checkName(id,name) {
var filter1 = /^[A-Za-z]+$/;
var filter2 =/[\u4E00-\u9FA5]{2,5}(?:·[\u4E00-\u9FA5]{2,5})*/;
if (filter1.test(name)||filter2.test(name)){
return true;
}
else {
alert("请输入名字,名字上不能出现数字或特殊字符");
id.focus();
return false;
}
}
</script>
当然也可以在submit按钮onClick提交,如:
<form name="myForm" action="http://www.baidu.com" method="get" >
name:<input name="name" type="text" /><br />
<input name="submit" type="submit" value="submit提交" onClick="return submitForm()"/>
</form>
<script>
function submitForm(){
var _form=document.forms[0];
//var _form=document.getElementsByName("myForm")[0];
//var _form=document.getElementsByName("myForm").item(0);
return checkName(_form.name,_form.name.value);
}
function checkName(id,name) {
var filter1 = /^[A-Za-z]+$/;
var filter2 =/[\u4E00-\u9FA5]{2,5}(?:·[\u4E00-\u9FA5]{2,5})*/;
if (filter1.test(name)||filter2.test(name)){
return true;
}
else {
alert("请输入名字,名字上不能出现数字或特殊字符");
id.focus();
return false;
}
}
</script>
把上面的代码换成button按钮
<form name="myForm" action="http://www.baidu.com" method="get" onSubmit="return submitForm()" >
name:<input name="name" type="text" /><br />
<input name="button" type="button" value="button提交"/>
</form>
<script>
function submitForm(){
var _form=document.forms[0];
//var _form=document.getElementsByName("myForm")[0];
//var _form=document.getElementsByName("myForm").item(0);
return checkName(_form.name,_form.name.value);
}
function checkName(id,name) {
var filter1 = /^[A-Za-z]+$/;
var filter2 =/[\u4E00-\u9FA5]{2,5}(?:·[\u4E00-\u9FA5]{2,5})*/;
if (filter1.test(name)||filter2.test(name)){
return true;
}
else {
alert("名字不能出现数字或特殊字符");
id.focus();
return false;
}
}
</script>
如上这一段代码点击提交按钮没反应,只能接受回车键提交事件,那在给botton按钮加上onClick="this.form.submit()"会不会触发提交事件呢?结果如愿的实现了一半!!——没有通过验证就直接提交了,只是直接执行了submit()事件提交了表单而已,没有执行onSubmit="return submitForm()"里的表单验证事件就提交了。
<form name="myForm" action="http://www.baidu.com" method="get" onSubmit="return submitForm()">
name:<input name="name" type="text" /><br />
<input name="button" type="button" value="button提交" onClick="this.form.submit()"/>
</form>
<script>
function submitForm(){
var _form=document.forms[0];
//var _form=document.getElementsByName("myForm")[0];
//var _form=document.getElementsByName("myForm").item(0);
return checkName(_form.name,_form.name.value);
}
function checkName(id,name) {
var filter1 = /^[A-Za-z]+$/;
var filter2 =/[\u4E00-\u9FA5]{2,5}(?:·[\u4E00-\u9FA5]{2,5})*/;
if (filter1.test(name)||filter2.test(name)){
return true;
}
else {
alert("名字不能出现数字或特殊字符");
id.focus();
return false;
}
}
</script>
如要让它接受回车键提交与点击提交都执行表单验证后再提交上服务器,只能再修改js了,如下代码修改过后能实现:
<form name="myForm" action="http://www.baidu.com" method="get" onSubmit="return submitForm()">
name:<input name="name" type="text" /><br />
<input name="button" type="button" value="button提交" onClick="submitForm()"/>
</form>
<script>
function submitForm(){
var _form=document.forms[0];
if (checkName(_form.name,_form.name.value)){
_form.submit();
}else{
_form.onSubmit=false;
return false;
}
}
function checkName(id,name) {
var filter1 = /^[A-Za-z]+$/;
var filter2 =/[\u4E00-\u9FA5]{2,5}(?:·[\u4E00-\u9FA5]{2,5})*/;
if (filter1.test(name)||filter2.test(name)){
return true;
}
else {
alert("名字不能出现数字或特殊字符");
id.focus();
return false;
}
}
</script>
表单验证提交——submit与button的更多相关文章
- 第一百五十四节,封装库--JavaScript,表单验证--提交验证
封装库--JavaScript,表单验证--提交验证 将表单的所有必填项,做一个判断函数,填写正确时返回布尔值 最后在提交时,判断每一项是否正确,全部正确才可以 提交 html <div id= ...
- 原生JS写表单验证提交功能
先上效果图: 表单的基础内容就是昵称判断.手机号判断.邮箱判断.身份证号码判断,这里是用到正则验证检验格式. 页面的表单写法就是一个form的提交.输入框用input来实现,输入内容用value来获取 ...
- MVC身份验证.MVC过滤器.MVC6关键字Task,Async.前端模拟表单验证,提交.自定义匿名集合.Edge导出到Excel.BootstrapTree树状菜单的全选和反选.bootstrap可搜索可多选可全选下拉框
1.MVC身份验证. 有两种方式.一个是传统的所有控制器继承自定义Control,然后再里面用MVC的过滤器拦截.所以每次网站的后台被访问时.就会先走入拦截器.进行前端和后端的验证 一个是利用(MVC ...
- form表单重复提交,type=“button”和type=“submit”区别
公司测试提了一个项目后台在IE浏览器下(360,firefox就没问题)出现数据重复的问题,调试了好久终于发现问题所在,也不知道是谁写的代码,醉醉的.... 错误地点: <input type= ...
- jquery.validate+jquery.form表单验证提交
1.通过jquery.validate的submitHandler选项,即当表单通过验证时运行回调函数.在这个回调函数中通过jquery.form来提交表单: <script type=&quo ...
- AngularJS的表单验证提交示例
代码下载:https://files.cnblogs.com/files/xiandedanteng/angularjsFormSubmit.rar 前台代码: <%@ page content ...
- Jquery插件easyUi表单验证提交
<form id="myForm" method="post"> <table align="center" style= ...
- jQuery Validatede 结合Ajax 表单验证提交
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- boostrap ajax表单验证提交
=============================================================================== 1. 1 <link href=& ...
随机推荐
- 列表框List Box
List Box/Check List Box ListBox窗口用来列出一系列的文本,每条文本占一行.创建一个列表窗口可以使用成员函数: BOOL CListBox::Create( LPCTSTR ...
- 解决jsp页面乱码问题
页面也需要设置转码的:页面:(.jsp) <%@ page language="java" import="java.util.*" pageEncodi ...
- DOM 之通俗易懂讲解
DOM是所有前端开发每天打交道的东西,但是随着jQuery等库的出现,大大简化了DOM操作,导致大家慢慢的“遗忘”了它的本来面貌.不过,要想深入学习前端知识,对DOM的了解是不可或缺的,所以本文力图系 ...
- PHP Java
http://my.oschina.net/lajp/blog/5121 http://blog.163.com/lijianwei_123/blog/static/18489289120115244 ...
- VA自动补全QT
发现用了一下,VA不能把QT的东西进行代码自动补全.于是要动下小手脚. 1.在Windows系统环境变量下增加 QTDIR = 你QT的安装目录. 2启动VS->工具->选项->项目 ...
- SpringMVC、Zookeeper、Dubbo使用
联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,Dubbo是一个分布式服务框架,在这种情况下诞生的.现在核心业务抽取出来,作为独立的服务,使前 ...
- rsyslog Properties 属性:
rsyslog Properties 属性: 数据项 在rsyslog 是被称为 "properties". 它们可以有不同的源, 最重要的是 那些来自接收的消息,但是还有其他. ...
- crontab,at命令,常见问题
crontab命令 前 一天学习了 at 命令是针对仅运行一次的任务,循环运行的例行性计划任务,linux系统则是由 cron (crond) 这个系统服务来控制的. Linux 系统上面原本就有非常 ...
- HDU_2058——等差数列,子集,集合长度判断
Problem Description Given a sequence 1,2,3,......N, your job is to calculate all the possible sub-se ...
- IT项目外包有哪些注意事项
2015年两会上,李克强总理在政府工作报告中首次提出“互联网+”计划,各种互联网创业项目也如雨后春笋般破土而出.由于很多创业团队并没有自己的技术团队,所以软件外包成为很多创业项目普遍采取的一种方案.在 ...