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参数。