jsp中form表单和ajax向后台传递数据

                                form表单和ajax向后台传递数据

我们有时候可能需要向后台传递一些数据。这时候我们有两种选择。

1:form表单

2:ajax请求

form表单是我们比较常用的,我们把我们需要传递的值放在form表单里的input框里。这个input框的name要声明。

然后我们在后台可以通过函数的参数获取对应name和参数名相等的值,或者我们可以通过request.getparameter("name")来获取。

那么ajax是怎么传递数据的呢 ?

var shopid="hello world";
	    $.ajax({
			type:"post",
			url:"${basePath_s}user/change",
			cache:false,
			async:false,
			data:{"shopid":shopid},
			dataType:"json",
			success:function(data,textStatus,jqXHR){
				window.location.href="${basePath_s}user/waiting";
			},
			error:function(XMLHttpRequest,textStatus,errorThrown){
			}
		})

显然我们也需要把数据传过去的时候封装成key,value的形式。这样我们在后台可以像获取表单数据那样获取ajax传递的参数。

那么有没有你有没有发现我们ajax参数中没有设置contentType。你会想不是默认的json格式么?其实如果可以的设置成

contentType:application/json。后台在获取的时候你却发现获取不到。因为发到后台的是一个字符串,自然无法通过key值获取

value。所以需要对传过来的字符串用java的gson.jar解析成json类型的数据。然后再通过key值获取value值。

jquery的ajax传递的contentType和form扁担传递的默认的是application/x-www-form-urlencoded。后台可以直接通过key获取。

原生的js默认的并不是这个,也不会获取得到值。

当我们传递比较大的数据是会把格式设置成application/json。但是一般用jq的ajax不会设置,因为一个请求并没有太的的数据发

送给后台,细想想也不合逻辑,特殊情况特殊处理。没有特殊需求还是不和建议设置ajax传递参数时的contentType参数。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值