zoukankan      html  css  js  c++  java
  • 【Jquery】jQuery 提交form表单并解析 url 参数

    应用场景: jquery + ajax 表单提交,一次性获取所有表单,并解析到post 参数

    常用点 1 :

    //获取所有表单参数: 结果格式为: a=1&b=2&c=3
    $('form').serialize(); 
    

    常用点 2 :jquery 解析 url参数

    //封装方法
    (function($) {
        var re = /([^&=]+)=?([^&]*)/g,
        decodeRE = /+/g,
        decode = function (str) { return decodeURIComponent( str.replace(decodeRE, " ") ); };
    
        $.parseParams = function(query) {
            let params = {}, e;
            while ( e = re.exec(query) ) params[ decode(e[1]) ] = decode( e[2] );
            return params;
        };
    })(jQuery);
    
    
    //使用方法 : 
    var formdata = 'a=1&b=2&c=3';
    var json_data = $.parseParams(formdata); //json_data 格式 : {a:1,b:2,c:3}
    
    

    完整使用的示例代码

    <!DOCTYPE html>
    <html>
    
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width,initial-scale=1,user-scalable=0,viewport-fit=cover">
        <title>login</title>
        <link rel="stylesheet" href="__CPLUGINS__/weui/css/weui.css" />
    </head>
    
    <body>
            
        <div class="weui-form__control-area">
            <div class="weui-form__text-area">
                <h2 class="weui-form__title">login</h2>
            </div>
    
            <form method="post" >
                <div class="weui-cells__group weui-cells__group_form">
                   <div class="weui-cells weui-cells_form">
                        <div class="weui-cell weui-cell_active">
                            <div class="weui-cell__hd"><label class="weui-label">用户名</label></div>
                            <div class="weui-cell__bd">
                                <input  class="weui-input" name="user_name"  placeholder="请输入"/>
                            </div>
                        </div>
                        <div class="weui-cell weui-cell_active">
                            <div class="weui-cell__hd"><label class="weui-label">密码</label></div>
                            <div class="weui-cell__bd">
                                <input  class="weui-input"  name="pass"  placeholder="请输入"  />
                            </div>
                        </div>
                    </div>
                </div>
            </form>
    
        </div>
    
        <div class="weui-form__opr-area">
            <a class="weui-btn weui-btn_primary" href="javascript:"  id='send'  >确定</a>
        </div>
       
    </body>
    
    <script type="text/javascript" src="__MJS__/jquery-2.1.0.js"></script>
    
    <script>
    
        //监听提交
        $('#send').on('click', function () {
            //获取所有的form表单参数
            var alldata = $('form').serialize(); 
            //此处调用下方的封装函数  
            form_param = $.parseParams(alldata);  
            //ajax请求
            $.post("/reg_send", {
                    user_name: form_param.user_name,
                    pass: form_param.pass,
                }, function (res) {
                    layer.msg(res.message)
                    if (res.status == 2) {
                        //成功
                    }
            });
            
            return false;
        });
    
    
    
        //解析参数: 此处是封装的函数,
        (function($) {
            var re = /([^&=]+)=?([^&]*)/g,
                decodeRE = /+/g,
                decode = function (str) { return decodeURIComponent( str.replace(decodeRE, " ") ); };
    
            $.parseParams = function(query) {
                let params = {}, e;
                while ( e = re.exec(query) ) params[ decode(e[1]) ] = decode( e[2] );
                return params;
            };
        })(jQuery);
    
    </script>
    
    </html>
    
    
    
  • 相关阅读:
    windows上docker部署springboot多实例
    oracle 如何搜索当前用户下所有表里含某个值的字段?
    VS2010/OpenGL配置
    (译)Minimal Shader(最小的着色器)
    (译)Cg Programming/Unity(Cg编程/Unity)
    (转)在Unity3D中控制动画播放
    Unity3d中使用assetbundle
    C# 操作 sqlite
    Unity3d网格合并
    在Unity3d中解析Lua脚本的方法
  • 原文地址:https://www.cnblogs.com/richerdyoung/p/13783069.html
Copyright © 2011-2022 走看看