用ajax提交form表单及乱码问题
要求
1. form里是习题和选择的答案包含内容较多,直接用ajax获取页面元素较多,麻烦。
2. 也不能直接用form提交,form提交后会跳转页面,如果出错想在本页面获取错误信息(ajax提交)且保存用户选择的答案,不用重复作答。
问题
1. 将form表单中提交的内容转给ajax提交。
2. 获取哪道题没做(上篇已解决)。
3. 需要替换form中参数的部分内容。
4. ajax 提交中文到后台是乱码。
解决
1. 用jquery的 var str = $("form").serialize(); 方法获得form提交的内容。
3. 用js的replace()方法,可以用正则表达式匹配,str = str.replace(/&optionId\d{1,3}/g, "&optionId"); 这里是将&option1,&option2等 替换成&option(因为后台接收的对象里包含的option是个数组)
4. 用js的encodeURL()方法,将中文编码两次,第一次var str = $("form").serialize(); 的str已经是编码一次的了,还需encodeURI(str)一次。
页面
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8" trimDirectiveWhitespaces="true"%>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt"%>
<%@taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions"%> <div class="u_main fr">
<div class="u_i_detail bodr u_height">
<div class="u_hd">
<h3>投资者风险评估</h3>
</div>
<div class="fx_pg">
<form id="riskEvauationSubmit"> <div class="pg_tit" align="center">
<h3>投资者风险评估测试</h3>
</div>
<div class="pg_tit">${riskEvaluation }</div> <c:forEach items="${list}" var="risk" varStatus="status">
<div class="pg_item">
<div class="pgt_bt">
${status.index+1}、<input type="text" name="title"
value="${risk.title }" /> <input type="hidden" name="stemId"
value="${risk.id }" /> <input type="hidden" name="type"
value="${risk.type }" />
</div>
<c:forEach items="${risk.option}" var="option"
varStatus="optionStatus">
<label class="pgt_list"> <c:if test="${risk.type == 1}"> <input type="radio" name="optionId${status.index}" /* redio每道题的name不能一样 要不然就是同一个redio了 */
class="optionId${status.index+1}" value="${option.id}">${option.content} </c:if> <c:if test="${risk.type == 2}"> <input type="checkbox" name="optionId${status.index}"
class="optionId${status.index+1}" value="${option.id}">${option.content} </c:if>
</label>
</c:forEach>
</div>
</c:forEach>
<div class="pg_butt">
<input id="submit" class="isave" value="立即评测"> <input
type="text" id="uuid" name="uuid" value="${uuid}" hidden="hidden" />
</div>
</form>
</div>
</div>
</div>
<script type="text/javascript">
$(function() {
$("#menu_loaningInvest").attr("class", "z_cur"); }) $("#submit") .click(
function() {
var count = parseInt("${count}"); for (var i = 1; i <= count; i++) {
var flag = false;
if ($("input[class='optionId" + i + "']:checked").length > 0) {
flag = true;
} if (flag == false) {
alert("第 " + i + " 题未作答,请选择答案!");
return false;
}
}
var str = $("form").serialize();
str = str.replace(/&optionId\d{1,3}/g, "&optionId");
$
.post(
"${pageContext.request.contextPath}/riskAssessment/saveRiskEvaluation?"
+ encodeURI(str),
function(data) {
if (data.code == 1) {
window.location.href = '../riskAssessment/riskEvaluationResult';
} else if (data.code == 0) {
alert("请勿重复点击,多次提交。");
$("#uuid").val(data.msg);
} else {
alert(data.msg);
}
});
})
</script>
后台接收的springMVC controller
@ResponseBody
@RequestMapping("/saveRiskEvaluation")
public ErrorInfo saveRiskEvaluation(HttpServletRequest request, RiskEvaluation riskEvaluation,String uuid){ ErrorInfo error = new ErrorInfo();
int result = 0;
Users user = userService.currentUser(request); //uuid防重复提交
if(!captchaUtil.checkUUID(uuid)){
String uuidNew = captchaUtil.getUUID();
error.code = 0;
error.msg=uuidNew;
return error;
} try {
result = riskEvaluationService.saveRiskEvaluation(riskEvaluation,user);
} catch (HandleException e) {
error.code = -1;
error.msg="网络异常,请稍后重试";
return error;
} if(result <= 0){
error.code = -1;
error.msg="网络异常,请稍后重试";
return error;
}
error.code = 1;
return error;
}
接收前台传过值的model
public class RiskEvaluation {
private String title[]; //题干 form里的name都一样
private String stemId[]; //题干id
private String optionId[]; //选项id 这是为什么传过来的optionId1,optionId2都必须是optionId
private String type[]; //题目类型
public String[] getStemId() {
return stemId;
}
public void setStemId(String[] stemId) {
this.stemId = stemId;
}
public String[] getType() {
return type;
}
public void setType(String[] type) {
this.type = type;
}
public String[] getTitle() {
return title;
}
public void setTitle(String[] title) {
this.title = title;
}
public String[] getOptionId() {
return optionId;
}
public void setOptionId(String[] optionId) {
this.optionId = optionId;
}
}
后台解码
title = java.net.URLDecoder.decode(title_arr[i], "utf-8");
用ajax提交form表单及乱码问题的更多相关文章
- ajax提交form表单
1. ajax提交form表单和不同的form表单的提交主要区别在于,ajax提交表单是异步提交的,而普通的是同步提交的表单. 2. from视图部分 <form id="loginF ...
- ajax提交form表单资料详细汇总
一.ajax提交form表单和不同的form表单的提交主要区别在于,ajax提交表单是异步提交的,而普通的是同步提交的表单.通过在后台与服务器进行少量数据交换,ajax 可以使网页实现异步更新.这意味 ...
- jquery实现ajax提交form表单的方法总结
本篇文章主要是对jquery实现ajax提交form表单的方法进行了总结介绍,需要的朋友可以过来参考下,希望对大家有所帮助 方法一: function AddHandlingFeeToRefund( ...
- jquery的ajax提交form表单方式总结
方法一: function AddHandlingFeeToRefund() { var AjaxURL= "../OrderManagement/AjaxModifyOrderServic ...
- Ajax提交Form表单的一种方法
待提交的表单 <form id="updatePublicKey" enctype="multipart/form-data"> <div c ...
- ajax提交form表单问题
form表单提交数据可以省下大量大量获取元素的代码,局部刷新时也可以用ajax提交form表单,但是要先把表单序列化,再把后台javaBean对象序列化,但是你有可能前后台都执行了系列化,但是后台还是 ...
- Ajax提交form表单内容和文件(jQuery.form.js)
jQuery官网是这样介绍form.js A simple way to AJAX-ify any form on your page; with file upload and progress s ...
- 使用ajax提交form表单,包括ajax文件上传【转载】
[使用ajax提交form表单,包括ajax文件上传] 前言 转载:作者:https://www.cnblogs.com/zhuxiaojie/p/4783939.html 使用ajax请求数据,很多 ...
- 使用ajax提交form表单,包括ajax文件上传 转http://www.cnblogs.com/zhuxiaojie/p/4783939.html
使用ajax提交form表单,包括ajax文件上传 前言 使用ajax请求数据,很多人都会,比如说: $.post(path,{data:data},function(data){ ... },&qu ...
随机推荐
- C#对.CSV格式的文件--逗号分隔值文件 的读写操作及上传ftp服务器操作方法总结
前言 公司最近开发需要将数据保存到.csv文件(逗号分隔值 文件)中然后上传到ftp服务器上,供我们系统还有客户系统调用,之前完全没有接触过这个,所以先来看看百度的解释:逗号分隔值(Comma-Sep ...
- DevExpress--navBarControl控件
一.在工具箱Navigation&Layout下找到控件navBarControl,拽到相应的位置. 二.点击控件右上角的小三角,对其进行设计:如下图 点Add group可迅速添加组列表,点 ...
- js当中的声明和初始化的顺序
if(!("a" in window)) { var a=1; } alert(a); 这里的alert出来undefined 这句话就相当于 var a; if(!(“a” in ...
- Zend_Frameowrk中进行多语言国际化的相关的配置和使用
在使用Zend_Framework建立网站,若网站在以后的使用中面向国际,这时就需要实现网站的多语言国际化问题.使用Zend_Framework开发的网站需要进行多语言的开发时,就需要用到了Zend_ ...
- C++ 类模板的使用
从事C++挺久了,在前段时看书时,发现高手,都是在写模板无,泛型编程,顿感差距.自己连模板都没有写,于是就小小的研究了下模板的用法. 模板简而言之就是对某此对象的相同方法,或处理方式,进行归纳,总结, ...
- 将excel文件批量转成pdf
防止数据编辑.改动带来的不一致性,常常要将excel文件转成pdf文件再共享.发送给对方.有时excel文件还挺多,手头上保存实在是太慢了.就考虑用VBA批量转置. 掌握几个东西,就比较容易了: 1. ...
- java的数据类型转换
java中有八种基本数据类型分别是字节型byte.整型int.短整型short.长整型long.单精度浮点型float.双精度浮点型double.字符型char.布尔型boolean.这些基本数据类型 ...
- JRE JDK JVM是什么
jre: Java Runtime Environment java运行环境 ----------------------------------------- jdk:Java Developmen ...
- 用户、角色、权限三者多对多用hibernate的一对多注解配置
用户.角色.权限三者多对多用hibernate的一对多注解配置 //权限表@Table(name = "p")public class P { @Id @GeneratedValu ...
- RTL-SDR + GnuRadio+RFcat 分析、重放无线遥控信号
0×00 前言 前段时间在<永不消逝的电波(二)HackRF入门:家用无线门铃信号重放> 一文中通过HackRF录制.重放了无线遥控信号,不过一直没来得及对信号进行分析,刚好在国外网站看到 ...