问题描述:

  最近进了一家“老公司”工作,说他老不是说他成立的早,是因为他的编程框架太l.......low了。EJB的规范模式,使用是IBM经过Eclipse二次开发出来的RAD(Rational Application Development),这软件也太重量级了,基本上占用CPU比例15%左右,内存4GB的跑不起来,然后JSP嵌套大量的Java代码和大量的JS代码,读起来超级累,没有那种分层。吐槽一下,回到主题。这几天的工作主要是改JSP和少量的Java代码,说到JSP当然少不了提交表单了。总结一下JSP几种提交表单的方法。

1.通过<form action="url"><input type="submit"></form>按钮方式提交

  这种方式是最传统的提交表单的方式,就是把所有的表单的值传到url界面。用于本页面传本页面比较多。

2.通过<input type="button" method="post/get" onclick="onSubmit()">

  这里是通过onclick触发js事件,然后我们可以在function onSubmit(){}写一些传输方式,比较典型的就是ajax传输:

 var j$ = jQuery.noConflict();//注册jQuery
function onSubmit(){
j$.ajax({
type:"get",
url:"fix_project_contrast_do.jsp",
data:{
fixitem_id : j$("#fixitem_id").val(),
check_man : j$("#check_man").val()
},
success:function(ret){
if(ret == 1) {
alert("提交审核成功!");
}else{
alert(ret); }
window.returnValue=true;
window.close();
}
});
}

然后我们可以在fix_project_contrast_do.jsp处理

 <%@ page contentType="text/html; charset=GBK"  import="相应的类路径" %>

 <%
try{ Integer fixitem_id = Utility.trimNull(request.getParameter("fixitem_id")), new Integer(0));
Integer check_man = Utility.parseInt(Utility.trimNull(request.getParameter("check_man")), new Integer(0));
//处理逻辑省略
out.clear();
response.getWriter().write("1");//response相应值
}catch(Exception e){
out.clear();
response.getWriter().write(e.getMessage());
} %>

这种ajax异步传输用于修改后保存然后刷新页面比较多。

扩展:

如果我上传的页面包含<input type="file">的时候,需要修改在我们form标签

<form name="form_name" name="form_loan_update" enctype="multipart/form-data" method="post"> 我们就要通过下面代码提交表单了,fileElementId:'form_name'是提交form_name整个表单

        jQuery.ajaxFileUpload({
async:false,
url:'fix_project_contrast_do.jsp',
secureuri:false,
fileElementId:'form_name',
dataType: 'json',
beforeSend:function(){
},
complete:function(){
},
success: function (data, status){
//表单参数
//次顺序
alert("保存成功");
window.location.reload();//刷新
},
error: function (data, status, e){
var result = Ext.MessageBox.show({
title: '事务表单异常',
msg: data.responseText,
width:,
closable:false
});
}
});
}

然后在fix_project_contrast_do.jsp接收数据的数据需要

  Integer fixitem_id = Utility.trimNull(file.getParameter("fixitem_id")), new Integer(0));

3.通过<form name="test" method="post" action="#"><input type="button" onclick="document.test.submit()"></form>

使用java代码实现相应的业务代码

 <%
if (request.getMethod().equals("POST")) {
/**逻辑代码
*1.获取参数
*2.处理参数,实现业务逻辑
*3.设置标识,用于通过js跳转页面或刷新页面
*/
bSuccess = true;
}
%>
<%if (bSuccess) {%>
alert("保存成功!");
var url = "对应的url参数";
location = url;
<%}%>

4.异步传输,实时监控表单数据

 <script type="text/javascript">
var req=false;//异步请求提交对象
//1、初始化异步请求提交对象
function init(){
if(window.ActiveXObject){//IE
req=new ActiveXObject("Microsoft.XMLHTTP");
}else{//firefox
req=new XMLHttpRequest();
}
}
//发送请求
function sendReq(){
init();
var sd=document.getElementById("stid").value;
//2、指定处理返回值的函数
req.onreadystatechange=process;
//3、打开到资源的连接
req.open("get","url",true);
//4、发送请求
req.send(null);
}
//5、处理返回值
function process(){
if(req.readyState==4){
if(req.status==200){
//获取返回值
var v=req.responseText;
var d=document.getElementById("divsid");
d.innerHTML=v;
}
}
}
</script>

5.$.post()提交表单,$.ajax的封装,原理和$.ajax一样。需要导入.jquery.js包

     js$.post("problem_invest_use_money_getCustInfo.jsp", {"fixitem_id" : fixitem_id}, function(data){
if(data != 0){
var params = data.split("$");
if(params[0] == 1){
document.getElementById("jkr_cust_id").value = params[1];
document.getElementById("jkr_cust_name").value = params[2];
}else{
alert(data)
}
}
});

其中回调函数data就是通过java代码:response.getWriter().write(returnString);返回

6.showModalDialog返回获取放回字符串

 function btnChoose(){
if(!sl_checkChoice(document.theform.fixitem_id, "项目ID")) return false;
if(!sl_checkChoice(document.theform.jj_contract_sub_bh, "合同编号")) return false;
var fixitem_id = document.getElementById("fixitem_id").value;
var jj_contract_bh = document.getElementById("jj_contract_sub_bh").value;
var v = showModalDialog('/efifs/zhongjiantou/repayment_principal_plan_choose.jsp?fixitem_id='+fixitem_id+'&jj_contract_bh='+jj_contract_bh,'','dialogWidth=1000px;dialogHeight=800px;status=no;help=0');
var params = v.split("$");
document.getElementById("money").value = params[0];
document.getElementById("lx_money").value = params[1];
document.getElementById("plan_id_list").value = params[2];
}

其中 v = window.returnValue = returnString;

总结:JSP几种提交表单方法的更多相关文章

  1. C# 另一种提交表单

    一般提交表单的方式就是:Get,Post 以及关联action 今天看了一种方式感觉不错: 可以在submit里面写 PostBackUrl="XXXX",即回发的URL,可以实现 ...

  2. Mvc 提交表单的4种方法全程详解

    一,MVC  HtmlHelper方法 Html.BeginForm(actionName,controllerName,method,htmlAttributes){} BeginRouteForm ...

  3. Mvc 提交表单的4种方法

     一,MVC  HtmlHelper方法 1.     Html.BeginForm(actionName,controllerName,method,htmlAttributes){} 2.     ...

  4. jsp中普通按钮如何提交表单

    jsp中普通按钮如何提交表单方法1: <form action = "提交的地址">         <input type="submit" ...

  5. C# MVC提交表单的四种方式(转)

    Mvc 提交表单的4种方法全程详解(转) 一,MVC  HtmlHelper方法 Html.BeginForm(actionName,controllerName,method,htmlAttribu ...

  6. MVC中提交表单的4种方式

    一,MVC  HtmlHelper方法 Html.BeginForm(actionName,controllerName,method,htmlAttributes){} BeginRouteForm ...

  7. JSP提交表单的几种方法

    1.通过<form action="url"><input type="submit"></form>按钮方式提交 这种方式 ...

  8. 在jsp提交表单的参数封装到一个方法里

    建议去看一下孤傲苍狼写的Servlet+JSP+JavaBean开发模式(http://www.cnblogs.com/xdp-gacl/p/3902537.html), 最好把他JavaWeb学习总 ...

  9. 利用JS提交表单的几种方法和验证

    第一种方式:表单提交,在form标签中增加onsubmit事件来判断表单提交是否成功 <script type="text/javascript"> function ...

随机推荐

  1. Node.js 教程 03 - 创建HTTP服务器

    前言: 如果我们使用PHP来编写后端的代码时,需要Apache 或者 Nginx 的HTTP 服务器,并配上 mod_php5 模块和php-cgi. 从这个角度看,整个"接收 HTTP 请 ...

  2. GreenPlum高效去除表重复数据

    1.针对PostgreSQL数据库表的去重复方法基本有三种,这是在网上查找的方法,在附录1给出.但是这些方法对GreenPlum来说都不管用. 2.数据表分布在不同的节点上,每个节点的ctid是唯一的 ...

  3. qt中ui的 使用介绍

    1.什么是ui?ui通常是用Qt 设计师设计出来的界面文件的后缀.通常情况下ui是一个指向这个界面类的指针.ui-> 一般就是用来访问这个界面类里面的控件.例如你的ui文件里有一个叫okButt ...

  4. 关于Retinex图像增强算法的一些新学习。

    最近再次看了一下IPOL网站,有一篇最近发表的文章,名字就是Multiscale Retinex,感觉自己对这个已经基本了解了,但还是进去看了看,也有一些收获,于是抽空把他们稍微整理了下,原始文章及其 ...

  5. SVM一点心得体会

    支持向量机的学习说是刚刚开始,又不合理,只能说隔了很长的时间再看,终于在分类这块的层面上有了新的认识. 总的来说,支持向量机分为线性支持向量机和非线性支持向量机,线性支持向量机又可以分为硬间隔最大化线 ...

  6. 机器学习之sklearn——SVM

    sklearn包对于SVM可输出支持向量,以及其系数和数目: print '支持向量的数目: ', clf.n_support_ print '支持向量的系数: ', clf.dual_coef_ p ...

  7. setTimeout和setInterval从入门到精通

    我们在日常web前端开发中,经常需要用到定时器方法. 前端中的定时器方法是浏览器提供的,并不是ECMAScript规范中的.是window对象的方法. 浏览器中的定时器有两种, 一种是每间隔一定时间执 ...

  8. 滑动验证的设计与实现J2EE

    滑动验证的设计与实现J2EE 注:本博文为博主原创,转载请注明出处. 项目源码地址:https://github.com/zhangxy1035/Verify 本篇博文的主要目录如下: 一.项目简介二 ...

  9. Gc.Db之循序渐进

    距离上次写Gc.Db框架已经有一段时间了,最近默默对框架代码已经做了不少优化和功能,且已经提交至nuget,大家如果想使用此框架,可以通过nuget搜索:Gc.Db进行下载和安装包. 本篇文章主要是介 ...

  10. input type="datetime-local" 时placeholder不显示

    一个坑,input的type="datetime-local" 时,电脑上会显示提示,如图 <input type="datetime-local" na ...