zoukankan      html  css  js  c++  java
  • form表单的6种提交方式

    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>
  • 相关阅读:
    How to Use HyperV Snapshot Revert, Apply, and Delete Options
    读取含有命名空间xml文件内容
    C# 如何判断文件属性(like: readonly)
    Winform: how to cancel the winform close when click the "x" button
    Android 程序打包及签名 【图解】
    【转】近两日极为纠结——游戏服务器,选择何种技术方案?(Python + SWIGRakNet + Lua)
    apk打包和反编译三、有关 Conversion to Dalvik format failed with error 1
    (转)投票软件识别验证码思路及方法
    如何解决Android中输入法挡住输入框的问题
    A folder failed to be renamed or moved安装Android SDK的问题
  • 原文地址:https://www.cnblogs.com/ms-grf/p/7657624.html
Copyright © 2011-2022 走看看