var searchClick=false;//判断是否是第一次点击搜索
//当搜索按钮被单击时触发
function searchData(){
//创建jqGrid组件
console.log('正在搜索');
var ele=jQuery('#searchForm'); var search='';
var searchArr=[];
for(item in ele[0]){
if(ele[0][item]!==null&&ele[0][item].name!==undefined&&ele[0][item].value!=undefined&&ele[0][item].name.length>0){ // if(ele[0][item].type.indexOf('checkbox')>-1){//如果是复选框 // search.length<1?(search=ele[0][item].name+'='+ele[0][item].checked):(search+='&'+ele[0][item].name+'='+ele[0][item].checked);
// searchArr[ele[0][item].name]=ele[0][item].checked;
// }else{
search.length<1?(search=ele[0][item].name+'='+ele[0][item].value):(search+='&'+ele[0][item].name+'='+ele[0][item].value);
searchArr[ele[0][item].name]=ele[0][item].value;
//} }
} if(!searchClick){ jQuery("#tableDataSearch").jqGrid(
{
url : 'url?'+search,//组件创建完成之后请求数据的url
datatype : "json",//请求数据返回的类型。可选json,xml,txt
overrite : true,
colNames : ['单号','金额','预约单号','日期','提成金额','是否退单'],//jqGrid的列显示名字
colModel: [ //jqGrid每一列的配置信息。包括名字,索引,宽度,对齐方式.....
{name: 'HBillNum',index: 'HBillNum',width:85,editable: false},
{name: 'HAmount',index: 'HAmount',width:85,editable: false},
{name: 'HOrderNo',index: 'HOrderNo',width:85,editable: false},
{name: 'HBillDate',index: 'HBillDate',width:85,editable: false},
{name: 'Commission',index: 'Commission',width:85,editable: false},
{name: 'Hredordernum',index: 'Hredordernum',width:85,editable: false},
],
height:'600',
width:window.screen.availWidth-400,
viewrecords: true,//是否在浏览导航栏显示记录总数
rownumbers:true,
rowNum : 10000,
pager : '#paper2',
sortname:'HBillDate',//默认的排序列名
sortorder : "desc",
//autowidth:true,
footerrow:true,
onSelectRow:function(id){
currentSelectedRecord={'HBillNum':jQuery(jQuery('#'+id)[0]['innerHTML'])[1].innerHTML,
};
},
loadComplete: function() { var grid = $("#tableDataSearch");
var ids = grid.getDataIDs();
if($(this).getGridParam('userData') == 'ceod1'){
$.messager.alert('提示','请把线上小程序的APPid填上');
}else if(ids.length < 1){
$.messager.alert('提示','"未查到所符合数据');
} for (var i = 0; i < ids.length; i++) {
grid.setRowData ( ids[i], false, {height: 25} );
}
//数据汇总
var HAmount=parseFloat(jQuery(this).getCol('HAmount', false, 'sum')).toFixed(2);
var Commission=parseFloat(jQuery(this).getCol('Commission', false, 'sum')).toFixed(2);
$(this).footerData("set", {rn:'合计', HAmount:HAmount,Commission:Commission,});
}
}).trigger("reloadGrid"); test='';
/*创建jqGrid的操作按钮容器*/
/*可以控制界面上增删改查的按钮是否显示*/
jQuery("#tableDataSearch").jqGrid('navGrid', '#paper2', {edit : false,add : false,del : false});
searchClick=true;
}else{
var params={};
Object.assign(params,searchArr); var postData = $('#tableDataSearch').jqGrid("getGridParam", "postData");
$.each(postData, function (k, v) {
delete postData[k];
});
jQuery("#tableDataSearch").jqGrid('setGridParam', {
url:'url?'+search,
datatype:'json',
postData: postData,
page: 1
}).trigger('reloadGrid'); }
return false;
}

出现这种问题一开始以为是缓存之类的东西,但是后台经过查询发现这个应该是jqgrid组件的BUG,jqgrid的方法 setGridParam方法自身会累加postdata的值”,需要像清空属性那样(delete property_name)清空上次请求参数才行。

我的方法

var postData = $('#tableDataSearch').jqGrid("getGridParam", "postData");
$.each(postData, function (k, v) {
delete postData[k];
});

jqgrid点击搜索无法重置参数问题的更多相关文章

  1. jqgrid后台处理搜索

    jqgrid后台处理搜索, 如果点击jqgrid自带的搜索,则向后台传递“_search”参数,和searchField.searchOper.searchString三个值.如下所示: string ...

  2. 利用referer属性,记录百度搜索跳转参数

    从百度搜索结果跳转到指定链接前,百度会发送一些参数,可以利用referer属性,在本站访问时记录百度跳转来之前的一些参数. 利用百度跳转前参数,进行一些相关的seo优化. 目前所用到的一些参数说明如下 ...

  3. 【代码笔记】iOS-点击搜索按钮,或放大镜后都会弹出搜索框

    一, 效果图. 二,工程图. 三,代码. RootViewController.h #import <UIKit/UIKit.h> #import "CLHSearchBar.h ...

  4. IOS UISearchDisplayController 点击搜索出现黑条问题解决方案

    最近项目遇到一个很奇葩的问题 点击按钮启动 presentViewController 的时候出现下图效果: 代码: AddFriendViewController *addFriendVC = [[ ...

  5. button点击传多个参数

    // --------------------button点击传多个参数------------------------ UIButton *btn = [UIButton buttonWithTyp ...

  6. 在iOS中,实现点击搜索结果隐藏搜索结果的方法。

    不知道有没有别的什么的好的方法,最近在实现一个需求(点击搜索,然后输入搜索内容,显示搜索出来的结果,然后点击搜索结果,在当前页面显示所点击的结果的详细的信息).遇到的问题是,点击搜索结果的时候,搜索的 ...

  7. [原]用WebBrowser组件模拟人工运行搜索引擎自动点击搜索结果的实验

    本代码只是业余时间无聊写着试试,用WebBrowser组件模拟人工运行搜索引擎自动点击搜索结果的实验 这是网络中盛传的提高搜索引擎点击率的一种方式,当然属于作弊,不推荐各位使用.另外这种方式的性能不佳 ...

  8. 点击搜索取消UISearchDisplayController的搜索状态

    一般,我们用到UISearchDisplayController的时候,都是须要对一个数据源进行刷选,在UISearchDisplayController自带的tableView中展示出来,然后点击退 ...

  9. 点击搜索条件提交form表单

    思路:点击搜索,javascript跳转提交方法,提交整个表单. //组员下拉框选择分组事件 $('#s-member').change(function(){ $('#logForm').submi ...

随机推荐

  1. Servlet-Context学习笔记

    介绍 ServletContext其实就是全局作用域对象, 上下文环境对象 利用context可以实现对,当前网站中所有的Servlet共享数据 context对象只能由Tomcat负责创建,在tom ...

  2. AX2012 ERP Excel报表方案

    AX提供了丰富的报表方式,内置X++开发的报表.基于微软ReportingService的报表.每个界面都可以导出Excel.Management Reporter.实施ERP最主要的二开工作就是完成 ...

  3. Windows下搭建Python虚拟环境

    一.安装使用 virtualenv 1. 安装 virtualenv pip install virtualenv 2. 新建虚拟环境 virtualenv env1 用 Python3 创建虚拟环境 ...

  4. WebApp的自动测试工具: Jenkins

    一.下载并安装(msi)https://jenkins.io/download/thank-you-downloading-windows-installer-stable/ 在安装过程这, 需要从p ...

  5. 命令纠正工具 thefuck 的简单使用

    在unix系列的系统中,总会出现 命令拼写或者执行错误的情况, 比如 把 python 写成了pythou, cd 到一个不存在的目录,执行任务的权限 不够的问题, 这是心里 总是 在 fuck,但是 ...

  6. JS和CSS交互的方法

    用JavaScript获取伪元素(pseudo-element)属性  var  color=window.getComputedStyle( document.querySelector('.ele ...

  7. Oracle根据主键获取对应表,Oracle根据外键获取相关表

    Oracle根据主键获取对应表 select * from user_constraints a, USER_CONS_COLUMNS b where a.CONSTRAINT_TYPE = 'P' ...

  8. nginx功能扩展整理

    0.基本负载均衡配置 编辑/etc/nginx/nginx.conf,加入负载平衡配置: http { upstream tomcat { server localhost:8080; server ...

  9. Python爬虫与数据分析之模块:内置模块、开源模块、自定义模块

    专栏目录: Python爬虫与数据分析之python教学视频.python源码分享,python Python爬虫与数据分析之基础教程:Python的语法.字典.元组.列表 Python爬虫与数据分析 ...

  10. 遍历删除查临时表相关session再操作表

    示例如下 删除 inf_getuserinfoforywh_temp1 (前提,相关用到inf_getuserinfoforywh_temp1的应用必须先停了) create or replace p ...