form表单提交方式

简介: form表单提交方式

无刷新页面提交表单

表单可实现无刷新页面提交,无需页面跳转,如下,通过一个隐藏的iframe实现,form表单的target设置为iframe的name名称,form提交目标位当前页面iframe则不会刷新页面

<form action="/url.do" method="post" target="targetIfr">
<input type="text" name="name"/>
</form>   
<iframe name="targetIfr" style="display:none"></iframe> 

通过type=submit提交

一般表单提交通过type=submit实现,input type=“submit”,浏览器显示为button按钮,通过点击这个按钮提交表单数据跳转到/url.do

<form action="/url.do" method="post">
   <input type="text" name="name"/>
   <input type="submit" value="提交">
</form>

js提交form表单

js事件触发表单提交,通过button、链接等触发事件,js调用submit()方法提交表单数据,jquery通过submit()方法

<form id="form" action="/url.do" method="post">
   <input type="text" name="name"/>
</form>
js: document.getElementById("form").submit();
jquery: $("#form").submit();

ajax异步提交表单数据

采用ajax异步方式,通过js获取form中所有input、select等组件的值,将这些值组成Json格式,通过异步的方式与服务器端进行交互,

一般将表单数据传送给服务器端,服务器端处理数据并返回结果信息等

<form id="form"  method="post">
   <input type="text" name="name" id="name"/>
</form>
var params = {"name", $("#name").val()}
$.ajax({
     type: "POST",
     url: "/url.do",
     data: params,
     dataType : "json",
     success: function(respMsg){
     }
  });

页面无跳转

如果通过form表单提交请求服务端去下载文件,这时当前页面不会发生跳转,服务端返回void,通过response 去写文件数据,页面会显示下载文件。

<form action="/url.do" method="post">
   <input type="text" name="name"/>
   <input type="submit" value="提交">
</form>
@RequestMapping(value = "/url")
    public void exportFile(HttpServletRequest req, HttpServletResponse response, String rptId)
            throws Exception {
        OutputStream out = null;
        try {
            String rptName = "file";
            String fileName = new String((rptName + excelAble.getFileSuffix()).getBytes("GBK"),
                    "8859_1");
            response.reset();
            response.setContentType("application/octec-stream");
            response.setHeader("Content-disposition", "attachment; filename=" + fileName);
            out = response.getOutputStream();
            excelAble.exportFile(out);
        } catch (Exception e) {
            logger.error(e);
        } finally {
            if (out != null) {
                out.close();
            }
        }
    }      

form表单上传文件

使用form表单进行上传文件需要为form添加enctype=“multipart/form-data” 属性,除此之外还需要将表单的提交方法改成post,如下 method=“post”, input type的类型需要设置为file

<form action="/url.do" enctype="multipart/form-data" method="post">
    <input type="file" name="name"/>
    <input type="submit" value="提交">
  </form>


相关文章
|
2月前
获取form表单提交的内容
获取form表单提交的内容
|
2月前
提交form表单判断是文件还是文本
提交form表单判断是文件还是文本
18 0
|
8月前
|
小程序 前端开发 JavaScript
小程序提交form表单
微信小程序提交form表单内容
64 0
|
8月前
|
前端开发
a标签以post方式提交
a标签以post方式提交
|
9月前
|
JavaScript
一个form表单有两个按钮,分别提交到不同的页面
一个form表单有两个按钮,分别提交到不同的页面
45 0
|
设计模式 JavaScript 数据库
表单防止重复提交的四种方式
表单防止重复提交的四种方式
208 0
|
前端开发 程序员
提交文件至服务器的设置——表单属性中的 enctype
提交文件至服务器的设置——表单属性中的 enctype
221 0
提交文件至服务器的设置——表单属性中的 enctype
form表单只提交数据而不进行页面跳转的原因
form表单只提交数据而不进行页面跳转的原因
267 0
form表单只提交数据而不进行页面跳转的原因
|
JSON 前端开发 数据格式
如何优雅的获取Form表单数据?
如何优雅的获取Form表单数据?
如何优雅的获取Form表单数据?
|
XML JSON 前端开发
表单校验与4种提交方式
表单是一个包含表单元素的区域。表单元素允许用户在表单中输入内容,比如:文本域(textarea)、下拉列表、单选框(radio-buttons)、复选框(checkboxes)等等。表单校验是指:用户在html页面的form表单中填写的内容,在向服务器提交之前,需要在前端完成对表单内的数据完整性和正确的格式进行校验,校验不通过不予以提交并给出提示。以避免服务器收到错误数据(导致对服务器的多余访问)。常用于表单的校验业务如下:非空(账号密码)、手机号格式、邮箱格式、密码复杂度。 表单提交的常见操作方式:1、表单中使用submit提交按钮。2、form表单使用onsubmit等等。 ​
1190 0
表单校验与4种提交方式