常用的页面提交方式

本文来总结一下,常用的页面提交方式。

提到常用,大家就要注意了。如果你选用的方式不常用,那么你就该思量一下自己的设计或者程序了。还是要站在巨人的肩膀上,才能创造出好的东西。


其实,本文将要讲的几种方式都比较常用。

常用就是合适的时候,做合适的事情。合适的技术,用在合适的地方,就是好的设计;就像合适的时间,遇到合适的人一样心有灵犀。


方式一:

常用的form提交。

该种方式提交页面,页面会进行跳转。这种方式可以选择post提交方式,还是get提交方式,一般情况下,提交form通用post。这种方式,很常用。

var form = document.getElementById("frm01");
            form.action ="<%=basePath %>test/productShow.action";
            form.method = "post";
            form.submit();


方式二:

拼接参数在url后面。

这种方式,为get提交方式。参数会列在url后面。该种方式同样最常用,但是要注意传递的参数的保密性,以及参数的长度限制。

window.location.href="<%=basePath%>test/productDetails.shtml?productId="+$("#productId").val() +"&detailUrl="+$("#detailUrl").val() ; 


方式三:

Ajax提交form的方式。

这种方式,会提交整个frm01,并且局部刷新。如果需要页面跳转,也可以结合其他页面跳转的方式,在success的function中进行页面跳转。

$.ajax({
                 	type:'post',
                     url: '<%=basePath %>test/productShow.shtml', 
                     data:$("#frm01").serialize(),
                     dataType:'json',  
                     cache: false, 
                     success : function(data) {}  

});


方式四:

Ajax拼接参数提交。

该种方式,类似上面的方式,只不过是相当于将参数拼接在url后面。而不是整个form提交。同样,该种方式,页面不会进行跳转,且局部刷新。

$(".send_msg").click(function(){
	    		 $.ajax({
	             	type:'post',
	             	async:true,
	                url: "<%=basePath%>test/productShow.shtml",
	                data:"product.productId="+$("#productId").val() +"&product.productName="+      
	                        $("#productName").val()+"&product.logo="+$("#logo").val(),
	               	dataType:'json',  
	                cache: false,
	                success : function(data) {}  
	             });
})


方式五:

多项选择时,提交。

$("#realBuy").bind("click",function(){
          			var ids=new Array();
          			var itemNos=new Array();
          			$(".payItemBox ul li").filter(".selected").each(function(index){
          				ids.push($(this).prev().prev().val());
          				itemNos.push($(this).prev().val());
          			});
          			$("input[name='theoryrepayids']").val(ids.join(","));
          			$("input[name='itemNos']").val(itemNos.join(","));
          			$("input[name='total']").val(sum.toFixed(2));
          			$("#repForm").submit();
          		});


方式六:

跳到该页面后,自动提交,并完成跳转。

该种方式,一般在做支付跳页时用。

<form action="https://yintong.com.cn/llpayh5/authpay.htm"
				method="post" name="mainform" id="mainform">
				<input type="hidden" name="req_data" value='${req_data}' />
	</form>
	<script type="text/JavaScript"> 
					mainform.submit(); 

</script>


总结:

1、为了避免form套form的情况,我们可以构造一个newForm,将需要的参数,通过js赋值过去,提交这个newForm即可;

2、有些参数,不适合在页面之间传来传去,比如一个订单的金额、购买的数量之类的,那么我就可以紧着重要的传递,然后再到数据库中查询【注意数据一致性的问题】,具体问题具体分析;

3、合适的时候,使用合适的技术,这样时间长了,才能做到游刃有余。不然就是南辕北辙,不断积累失败的经验。


4、偷偷的告诉自己:该好好学写一下JQuery啦!因为不熟悉,已经吃了不少亏了。。。

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值