form提交的几种方法

最近研究了下html中,form保单提交的几种方法,现与大家分享一下(注:网上可能已经有好多版本了,这里自己写下来做个总结了,哈!):

方法一:利用form的onsubmit()函数(经常使用)

 

<script type="text/javascript">
    function validateForm(){
  	if(document.reply.title.value == ""){ //通过form名来获取form
  		alert("please input the title!");
  		document.reply.title.focus();
  		return false;
  	}  	
  	if(document.forms[0].cont.value == ""){ //通过forms数组获取form
  		alert("please input the content!");
  		document.reply.cont.focus();
  		return false;
  	}
  	return true;
  }
<form name="reply"  method="post" οnsubmit="return validateForm( );">
        <input type="text" name="title"  size="80" /><br />
        <textarea name="cont" cols="80" rows="12"></textarea><br />
        <input type="submit" value="提交" >
</form>
注意:
1.onsubmit属性内容一定要有return关键字,否则函数会直接执行,不会返回
2.validateForm一定要返回一个boolean类型的返回值
3.提交按钮要写成submit类型的

 

方法二:利用input类型为submit组件的onclick()函数

    1.将上面form标签中的οnsubmit="return validateForm()"属性,去掉。

    2.为“提交”按钮添加onclick事件,如下:

     <input type="submit" value="提交" οnclick="return validateForm();">

 

方法三:利用button组件的onclick()函数,手动提交

<script type="text/javascript">
	function modifyItem() {
		if (trim(document.getElementById("itemName").value) == "") {
			alert("物料名称不能为空!");
			document.getElementById("itemName").focus();
			return;
		} 
		with (document.getElementById("itemForm")) {
			method = "post";
			action = "item.do?command=modify&pageNo=${itemForm.pageNo}";
			submit();
		}
	}
	//返回
	function goBack() {
		window.self.location = "item.do?command=list&pageNo=${itemForm.pageNo}";
	}
</script>
<form name="itemForm" id="itemForm">
      <input name="itemNo" type="text"   id="itemNo" value="${ item.itemNo }" >
      <input name="itemName" type="text"   id="itemName" value="${ item.itemName }" >
     <input name="btnModify"  type="button" id="btnModify" value=“修改" οnclick="modifyItem()">
</form>
注意:
1.提交时,设置form的action和methods属性,然后利用form.submit()函数提交。

 总结:

       1.对form中的组件验证时,前两个使用的是name属性,包括form自身的。

       2.如果提交表单时没有反应,同时确定提交表单部分代码没有问题,请查看提交表单前面的js代码,有时前面js的错误会引发莫名其妙的问题。

 

form 表单的提交有以下几种方式: 1. GET 方法提交:当表单的 `method` 属性设置为 `GET` 时,表单数据会附加在 URL 的查询参数中,通过 GET 请求发送给服务器。这种方式适用于对数据安全性要求不高、数据量较小的情况,例如搜索表单。 2. POST 方法提交:当表单的 `method` 属性设置为 `POST` 时,表单数据会作为请求的内容体发送给服务器。这种方式适用于传输敏感数据或者数据量较大的情况,例如用户注册或登录表单。 3. AJAX 提交:使用 JavaScript 的 XMLHttpRequest 或 Fetch API,可以通过异步的方式将表单数据发送给服务器。这种方式可以在不刷新整个页面的情况下发送数据,并且可以处理服务器返回的结果,实现无刷新的交互效果。 4. File Upload 提交:当表单包含文件上传字段时,可以使用特殊的 enctype 属性(如 `enctype="multipart/form-data"`)以及相应的后端处理逻辑来实现文件的上传。这种方式适用于需要上传文件的场景,例如上传图片、视频等。 5. 使用 JavaScript 提交:通过 JavaScript 可以监听表单的提交事件,并自定义处理逻辑。可以使用 JavaScript 构建请求并将表单数据发送给服务器,例如使用 Fetch API 或其他 AJAX 库来完成提交操作。 需要注意的是,在表单提交时,通常会通过设置 `action` 属性指定处理表单数据的后端地址。同时,表单字段需要通过 `name` 属性来标识,以便后端能够正确解析和处理数据。 根据具体的需求和场景,可以选择适合的提交方式来实现表单数据的传输和处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值