js ajax方式拼接参数

项目采用前端easyui+后端handler方式,一个老套的组合,比较适合当前的团队。

项目中有大量场景是做数据展示,主要是收集表单上的参数,统一提交到后端进行sql语句的拼装然后json序列化到前端grid控件上。

为减少前后端代码量,约定好前端和后端字段保持一致,前端封装一个js函数负责收集参数提交到后端,后端动态解析转换为sql语句where部分。

//获取容器的键值对
function getParams(elem) {
    var params = {};
    $(elem).find("*").each(function () {
        if ($(this).attr("name")) {
            var key = $(this).attr("name");
            var value = "";
            if ($(this).val()) {
                value = $(this).val();
            } else {
                value = $(this).text()
            }
            if (value != "") {
                params[key] = value;
            }
        }
    });
    return params;
}
//将键值对组装为URL参数格式
var parseParam = function (param, key) {
    var paramStr = "";
    if (param instanceof String || param instanceof Number || param instanceof Boolean) {
        paramStr += "&" + key + "='" + encodeURIComponent(param) + "'";
    } else {
        $.each(param, function (i) {
            var k = key == null ? i : key + (param instanceof Array ? "[" + i + "]" : "." + i);
            paramStr += '&' + parseParam(this, k);
        });
    }
    return paramStr.substr(1);
};

 js提交的时候只需要传入参数的容器即可。

function search() {
            var params = getParams("#customtb");//收集容器里查询条件
            $('#myGrid').datagrid('load', { 't': 'search', keyWord: parseParam(params) });
  }

后端解析,如果不涉及条件的特殊处理,后端得到参数直接替换&为and即可,因项目中有时间字段,做了特殊处理。

public static string TranlateUrl2QueryString(string strParams)
        {
            string sql = "";
            if (!string.IsNullOrWhiteSpace(strParams))
            {
                string[] arrParams = strParams.Split('&'); //dtStart='2016-05-04' 
                List<string> list = new List<string>();
                foreach (string s in arrParams)
                {
                    if (s.ToLower().StartsWith("dtstart"))//时间的特殊处理
                    {
                        string[] keyPairs = s.Split('=');
                        string sqlKeyPairs = string.Format(" MODIFYON > to_date({0}, 'yyyy-MM-dd') ", keyPairs[1]);
                        list.Add(sqlKeyPairs); //sqlWhere += sqlKeyPairs;
                    }
                    else if (s.ToLower().StartsWith("dtend"))
                    {
                        string[] keyPairs = s.Split('=');
                        string sqlKeyPairs = string.Format(" MODIFYON < to_date({0}, 'yyyy-MM-dd') ", keyPairs[1]);
                        list.Add(sqlKeyPairs);
                    }
                    else
                    {
                        list.Add(s);
                    }
                }
                sql = Utils.URLDecode(" where " + string.Join(" and ", list));
            }
            return sql;
        }

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值