Jqgird 如何使用自带的search模块进行数据查询

当我们使用集成的搜索框,点击find 按钮的时候,页面会向后台发送一个请求:

http://localhost/GW/jcxxAction!ryxx_index_r.action?_search=true&nd=1523774629725&rows=5&page=1&sidx=&sord=asc&filters=%7B%22groupOp%22%3A%22OR%22%2C%22rules%22%3A%5B%7B%22field%22%3A%22job%22%2C%22op%22%3A%22cn%22%2C%22data%22%3A%22%E5%B7%A5%E7%A8%8B%22%7D%2C%7B%22field%22%3A%22trunname%22%2C%22op%22%3A%22eq%22%2C%22data%22%3A%225252%22%7D%5D%7D&searchField=&searchString=&searchOper=

这个请求里面主要包含了这么几个信息,分页查询的几个参数信息,例如:page,rows,sidx,sord。另外重要的一个参数就是加密后的filters,这个长的字符串参数包含了我们要查询的所有条件,后台如何来接收呢?

我的项目用的是Struts2,在action当中定义这么一个filters同名的string 变量,给他set,get方法。这样在action方法中就能获取到查询条件信息了。

System.out.println("查询条件:"+filters);

查询条件:{"groupOp":"AND","rules":[{"field":"job","op":"cn","data":"dsds"}]}

这就是查询条件的数据格式,

JSONObject jsonFilter = (JSONObject) JSONSerializer.toJSON( filters );  
    JSONArray rules = jsonFilter.getJSONArray("rules");  
    int rulesCount = JSONArray.getDimensions(rules)[0];  
    log.debug("Count Rules :" + rulesCount);  
for (int i = 0; i < rulesCount; i++) {  
    JSONObject rule = rules.getJSONObject(i);  
    log.debug("field :" + rule.getString("field"));  
    log.debug("op :" + rule.getString("op"));  
    log.debug("data :" + rule.getString("data"));  
} 



猜你喜欢

转载自blog.csdn.net/xq30397022/article/details/79951056