问题描述
我有一个要求定制jqGrid。但postData.Filters是未定义的。由于我是新来的jQuery和JavaScript,我无法找出究竟是什么问题,即使经过一天的努力。我使用下面的JavaScript。 / p>
<!DOCTYPE html>
< html xmlns =http://www.w3.org/1999/xhtml>
< head>
< title>< / title>
< link rel =stylesheettype =text / csshref =http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.24/themes/redmond/jquery-ui。 css/>
< link rel =stylesheettype =text / csshref =http://www.ok-soft-gmbh.com/jqGrid/jquery.jqGrid-4.4.1/css/ui。 jqgrid.css/>
< link rel =stylesheettype =text / csshref =http://www.ok-soft-gmbh.com/jqGrid/jquery-ui-multiselect/1.13.6/jquery。 multiselect.css/>
< style type =text / css>
html,body {
font-size:75%;
}
.ui-multiselect-menu {
font-size:1.2em;
}
.ui-jqgrid .ui-jqgrid-htable .ui-search-toolbar th {
height:auto;
}
< / style>
< script src =js / jquery-1.11.0.min.js>< / script>
< script src =js / jquery.jqGrid.min.js>< / script>
< script src =js / jquery.jqGrid.src.js>< / script>
< script src =js / i18n / grid.locale-en.js>< / script>
< script type =text / javascript>
$ .jgrid.no_legacy_api = true;
$ .jgrid.useJSON = true;
< / script>
< script type =text / javascript>
$ b $雇员编号:1.0,
姓名:Anubhav,
性别:男,
部门:发展,
公司 SOPRA,
薪水:100000
},
{
雇主ID:2.0,
姓名:Shailesh,
性别:男,b $ b部:发展,
公司:SOPRA,
薪水:10000
},
{
商业编号:3.0,
姓名:Deepak,
性别:男,
部门:销售,
:ROQUETTE,
薪水:20000
},
{
雇主ID:4.0,
姓名:Seema,
性别:女性,
部门:购买,
公司:ROQUETTE,
薪水:25000
}
]},
$ grid = $(#list2),
myDefaultSearch ='cn',
getColumnIndexByName = function(columnName){
var cm = $(this).j qGrid('getGridParam','colModel'),i,l = cm.length;
for(i = 0; i if(cm [i] .name === columnName){
return i; //返回索引
}
}
返回-1;
}
modifySearchingFilter = function(separator){
var i,l,rules,rule,parts,j,group,str,iCol,cmi,cm = this.p.colModel;
window.alert(Hello);
window.alert(this.p.postData.filters);
var filters = $ .parseJSON(this.p.postData.filters);
window.alert(Hello 2);
if(filters&&& filter.rules!== undefined&&& filters.rules.length> 0){
rules = filters.rules;
for(i = 0; i< rules.length; i ++){
rule = rules [i];
iCol = getColumnIndexByName.call(this,rule.field);
cmi = cm [iCol];
if(iCol> = 0&
((cmi.searchoptions === undefined || cmi.searchoptions.sopt === undefined)
&&(rule .op === myDefaultSearch))||
(typeof(cmi.searchoptions)===object&&
$ .isArray(cmi.searchoptions.sopt)&&
cmi.searchoptions.sopt [0] === rule.op)){
//仅对'contains'操作进行修改
parts = rule.data.split(separator);
if(parts.length> 1){
if(filters.groups === undefined){
filters.groups = [];
}
group = {
groupOp:'OR',
groups:[],
rules:[]
};
filters.groups.push(group); (j = 0,l = parts.length; j< l; j ++){
str = parts [j];
if(str){
// skip empty'',存在两次分隔符
group.rules.push({
data:parts [j] ,
op:rule.op,
field:rule.field
});
}
}
rules.splice(i,1);
i--; //跳过i ++
}
}
}
this.p.postData.filters = JSON.stringify(filters);
$ b $ dataInitMultiselect = function(elem){
setTimeout(function(){
var $ elem = $(elem),id = elem.id ,
inToolbar = typeof id ===string&& id.substr(0,3)===gs_,
options = {
selectedList:2,
height:auto,
checkAllText:all,
uncheckAllText:no,
noneSelectedText:Any,
open:function(){
var $ menu = $(。ui-multiselect-menu:visible);
$ menu.width(auto);
return;
}
},
$ options = $ elem.find(option);
if($ options.length> 0&& $ options [0] .selected){
$ options [0] .selected = false; //取消选择第一个选项
if(inToolbar){
options.minWidth ='auto';
}
$ elem.multiselect(options);
$ elem.siblings('button.ui-multiselect')。css({
width:inToolbar?98%:100%,
marginTop:1px,
marginBottom:1px,
paddingTop:3px
});
},50);
};
$ grid.jqGrid({
datatype:json,
data:jsonData,
colNames:[Emp ID,Name,Department ,Company,Salary],
colModel:[
{name:Emp ID,sorttype:'integer'},
{name:Name},
{
name:Department,width:100,align:'center',formatter:'select',edittype:'select',stype:'select',
editoptions:{value :'DEVELOPMENT; SALES; PURCHASE',defaultValue:'DEVELOPMENT',multiple:true},
searchoptions:{sopt:['eq','ne'],value:'DEVELOPMENT; SALES; PURCHASE',attr :{multiple:'multiple',size:4},dataInit:dataInitMultiselect}
},
{name:Company},
{name:Salary,sorttype: '}
],
cmTemplate:{editable:false},
rowNum:10,
mtype:GET,
rowList:[10,20,100],
pager:#pager2,
height:auto,
viewrecords:true,
gridview:true,
ignoreCase:true,
rownumbers:true,
cellEdit:true,
cellsubmit:clientArray,
editurl:clientArray,
sortname:'Emp ID',
caption:CDDI Sample Grid,
beforeRequest:function(){
modifySearchingFilter.call(this,',');
}
});
$ grid.jqGrid('filterToolbar',{search:true,searchOperators:true,stringResult:true,searchOnEnter:true,defaultSearch:'cn'});
$ grid.jqGrid('navGrid','#pager2',{edit:false,add:false,del:false,search:true},{},{},{
multipleSearch:true,
multipleGroup:true,
recreateFilter:true
});
});
< / script>
< / head>
< body>
< table id =list2>< / table>
< div id =pager2>< / div>
< / body>
< / html>
我看到您使用。
错误jqGrid postData.filters is undefined undefined可以很容易地通过添加行来修复。
pre $ if $
$ / code>
里面的 modifySearchingFilter
在行 var filters = $ .parseJSON(postData.filters);
。
之前,代码中的其他重要错误是使用数据类型:json
而不是数据类型:local
。选项数据类型:json
表示来自网格的数据将通过Ajax请求加载到由 url
b
$ b
另外一个错误是使用 data:jsonData
而不是 data:jsonData.Employees
。要明白 data
参数的值必须是一个数组。建议您不要在 colModel
的名称
属性中使用特殊字符(目前您的名称为 :雇员ID
)。 name
属性的值将被用作网格的一些内部元素的 id
,但空间将被使用jQuery和CSS作为分隔符和元字符(例如,请参阅)。所以我建议你把 name:Emp ID
更改为 name:EmpId
未来少了问题。
固定的演示程序将被罚款。它使用下面的代码:
$ $ $ $ $ $ $($) = {
Employees:[
{
EmpId:1.0,
Name:Anubhav,
Gender:Male,
Department:DEVELOPMENT,
Company:SOPRA,
薪水:100000
},
{
EmpId :
姓名:Shailesh,
性别:男,
部门:发展,
公司:SOPRA ,
薪水:10000
,
{
EmpId:3.0,
姓名:Deepak,
性别:男,
部门:销售,
公司:ROQUETTE,
薪水:20000
},
{
EmpId:4.0,
姓名:Seema,
性别:女性,
部门:购买,
公司:ROQUETTE,
薪水:25000
}
$ grid $(#list2),
myDefaultSearch =cn,
getColumnIndexByName = function(columnName){
var cm = $(this).jqGrid(getGridParam,colModel),i,l = cm.length;
for(i = 0; i if(cm [i] .name === columnName){
return i; //返回索引
}
}
返回-1;
},
modifySearchingFilter =函数(分隔符){
var i,l,rules,rule,parts,j,group,str,iCol,cmi,filters,
cm = $(this).jqGrid(getGridParam,colModel),
postData = $(this).jqGrid(getGridParam,postData);
if(postData.filters == null){
return;
}
filters = $ .parseJSON(postData.filters);
if(filters&&& filter.rules!== undefined&&& filters.rules.length> 0){
rules = filters.rules;
for(i = 0; i< rules.length; i ++){
rule = rules [i];
iCol = getColumnIndexByName.call(this,rule.field);
cmi = cm [iCol];如果(iCol> = 0&&
(((cmi.searchoptions === undefined || cmi.searchoptions.sopt === undefined)&&
rule .op === myDefaultSearch)||
(typeof(cmi.searchoptions)===object&&
$ .isArray(cmi.searchoptions.sopt)&&
cmi.searchoptions.sopt.length> 0&&
cmi.searchoptions.sopt [0] === rule.op))){
//仅对包含操作
部分= rule.data.split(分隔符);
if(parts.length> 1){
if(filters.groups === undefined){
filters.groups = [];
}
group = {
groupOp:OR,
groups:[],
rules:[]
};
filters.groups.push(group); (j = 0,l = parts.length; j< l; j ++){
str = parts [j];
if(str){
// skip empty,存在于两个分隔符中的一个
group.rules.push({
data:parts [j] ,
op:rule.op,
field:rule.field
});
}
}
rules.splice(i,1);
i--; //跳过我++
}
}
}
postData.filters = JSON.stringify(filters);
$ b $ dataInitMultiselect = function(elem){
setTimeout(function(){
var $ elem = $(elem),id = elem.id ,
inToolbar = typeof id ===string&& id.substr(0,3)===gs_,
options = {
selectedList:2,
height:auto,
checkAllText:all,
uncheckAllText:no,
noneSelectedText:Any,
open:function(){
var $ menu = $(。ui-multiselect-menu:visible);
$ menu.width(auto);
return;
}
($ options.length> 0&& $ options [0] .selected){
}
$ options = $ elem.find(option);
$ options [0] .selected = false; //取消选择第一个选项
if(inToolbar){
options.minWidth =auto;
}
$ elem.multiselect(options);
$ elem.siblings(button.ui-multiselect)。css({
width:inToolbar?98%:100%,
marginTop:1px,
marginBottom:1px,
paddingTop:3px
});
},50);
};
$ grid.jqGrid({
datatype:local,
data:jsonData.Employees,
colNames:[Emp ID,Name, Department,Company,Salary],
colModel:[
{name:EmpId,sorttype:integer,key:true},
{name:名称},
{
名称:Department,
width:160,
align:center,
edittype:select,
editoptions:{
value:DEVELOPMENT:DEVELOPMENT; SALES:SALES; PURCHASE:PURCHASE,
defaultValue:DEVELOPMENT,
multiple:true
},
stype:select,
searchoptions:{
sopt:[eq,ne],
value:开发:开发;销售:销售;购买:购买,
attr:{multiple:multiple,size:4},
dataInit:dataInitMultiselect
{name:Company},
{name:Salary,sorttype:integer,formatter:integer }
],
cmTemplate:{editable:false},
rowNum:10,
rowList:[10,20,100],
pager:#pager2 ,
height:auto,
viewrecords:true,
gridview:true,
ignoreCase:true,
rownumbers:true,
cellEdit: true,
cellubmit:clientArray,
editurl:clientArray,
sortname:EmpId,
caption:CDDI示例网格,
beforeRequest: function(){
modifySearchingFilter.call(this,,);
}
});
$ grid.jqGrid(filterToolbar,{
searchOperators:true,
stringResult:true,
searchOnEnter:true,
defaultSearch:myDefaultSearch
} );
$ grid.jqGrid(navGrid,#pager2,{edit:false,add:false,del:false},{},{},{},{
multipleSearch:true,
multipleGroup:true,
recreateFilter:true
});
});
I have a requirement to customize jqGrid. But postData.Filters is undefined. As I am new to jquery and javascript I am unable to find out what exactly is the issue, even after a day of efforts.
I am using the below javascript.
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<link rel="stylesheet" type="text/css" href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.24/themes/redmond/jquery-ui.css" />
<link rel="stylesheet" type="text/css" href="http://www.ok-soft-gmbh.com/jqGrid/jquery.jqGrid-4.4.1/css/ui.jqgrid.css" />
<link rel="stylesheet" type="text/css" href="http://www.ok-soft-gmbh.com/jqGrid/jquery-ui-multiselect/1.13.6/jquery.multiselect.css" />
<style type="text/css">
html, body {
font-size: 75%;
}
.ui-multiselect-menu {
font-size: 1.2em;
}
.ui-jqgrid .ui-jqgrid-htable .ui-search-toolbar th {
height: auto;
}
</style>
<script src="js/jquery-1.11.0.min.js"></script>
<script src="js/jquery.jqGrid.min.js"></script>
<script src="js/jquery.jqGrid.src.js"></script>
<script src="js/i18n/grid.locale-en.js"></script>
<script type="text/javascript">
$.jgrid.no_legacy_api = true;
$.jgrid.useJSON = true;
</script>
<script type="text/javascript">
$(function () {
'use strict';
var jsonData = {
"Employees": [
{
"Emp ID": 1.0,
"Name": "Anubhav",
"Gender": "Male",
"Department": "DEVELOPMENT",
"Company": "SOPRA",
"Salary": 100000
},
{
"Emp ID": 2.0,
"Name": "Shailesh",
"Gender": "Male",
"Department": "DEVELOPMENT",
"Company": "SOPRA",
"Salary": 10000
},
{
"Emp ID": 3.0,
"Name": "Deepak",
"Gender": "Male",
"Department": "SALES",
"Company": "ROQUETTE",
"Salary": 20000
},
{
"Emp ID": 4.0,
"Name": "Seema",
"Gender": "Female",
"Department": "PURCHASE",
"Company": "ROQUETTE",
"Salary": 25000
}
]},
$grid = $("#list2"),
myDefaultSearch = 'cn',
getColumnIndexByName = function (columnName) {
var cm = $(this).jqGrid('getGridParam', 'colModel'), i, l = cm.length;
for (i = 0; i < l; i += 1) {
if (cm[i].name === columnName) {
return i; // return the index
}
}
return -1;
},
modifySearchingFilter = function (separator) {
var i, l, rules, rule, parts, j, group, str, iCol, cmi, cm = this.p.colModel;
window.alert("Hello");
window.alert(this.p.postData.filters);
var filters = $.parseJSON(this.p.postData.filters);
window.alert("Hello 2");
if (filters && filters.rules !== undefined && filters.rules.length > 0) {
rules = filters.rules;
for (i = 0; i < rules.length; i++) {
rule = rules[i];
iCol = getColumnIndexByName.call(this, rule.field);
cmi = cm[iCol];
if (iCol >= 0 &&
((cmi.searchoptions === undefined || cmi.searchoptions.sopt === undefined)
&& (rule.op === myDefaultSearch)) ||
(typeof (cmi.searchoptions) === "object" &&
$.isArray(cmi.searchoptions.sopt) &&
cmi.searchoptions.sopt[0] === rule.op)) {
// make modifications only for the 'contains' operation
parts = rule.data.split(separator);
if (parts.length > 1) {
if (filters.groups === undefined) {
filters.groups = [];
}
group = {
groupOp: 'OR',
groups: [],
rules: []
};
filters.groups.push(group);
for (j = 0, l = parts.length; j < l; j++) {
str = parts[j];
if (str) {
// skip empty '', which exist in case of two separaters of once
group.rules.push({
data: parts[j],
op: rule.op,
field: rule.field
});
}
}
rules.splice(i, 1);
i--; // to skip i++
}
}
}
this.p.postData.filters = JSON.stringify(filters);
}
},
dataInitMultiselect = function (elem) {
setTimeout(function () {
var $elem = $(elem), id = elem.id,
inToolbar = typeof id === "string" && id.substr(0, 3) === "gs_",
options = {
selectedList: 2,
height: "auto",
checkAllText: "all",
uncheckAllText: "no",
noneSelectedText: "Any",
open: function () {
var $menu = $(".ui-multiselect-menu:visible");
$menu.width("auto");
return;
}
},
$options = $elem.find("option");
if ($options.length > 0 && $options[0].selected) {
$options[0].selected = false; // unselect the first selected option
}
if (inToolbar) {
options.minWidth = 'auto';
}
$elem.multiselect(options);
$elem.siblings('button.ui-multiselect').css({
width: inToolbar ? "98%" : "100%",
marginTop: "1px",
marginBottom: "1px",
paddingTop: "3px"
});
}, 50);
};
$grid.jqGrid({
datatype: "json",
data: jsonData,
colNames: ["Emp ID", "Name", "Department", "Company", "Salary"],
colModel: [
{ name: "Emp ID", sorttype: 'integer' },
{ name: "Name" },
{
name: "Department", width: 100, align: 'center', formatter: 'select', edittype: 'select', stype: 'select',
editoptions: { value: 'DEVELOPMENT;SALES;PURCHASE', defaultValue: 'DEVELOPMENT', multiple: true },
searchoptions: { sopt:['eq', 'ne'], value: 'DEVELOPMENT;SALES;PURCHASE', attr: { multiple: 'multiple', size: 4 }, dataInit: dataInitMultiselect }
},
{ name: "Company" },
{ name: "Salary", sorttype: 'integer' }
],
cmTemplate: { editable: false },
rowNum: 10,
mtype: "GET",
rowList: [10, 20, 100],
pager: "#pager2",
height: "auto",
viewrecords: true,
gridview: true,
ignoreCase: true,
rownumbers: true,
cellEdit: true,
cellsubmit: "clientArray",
editurl: "clientArray",
sortname: 'Emp ID',
caption: "CDDI Sample Grid",
beforeRequest: function () {
modifySearchingFilter.call(this, ',');
}
});
$grid.jqGrid('filterToolbar', {search:true, searchOperators: true, stringResult: true, searchOnEnter: true, defaultSearch: 'cn' });
$grid.jqGrid('navGrid', '#pager2', { edit: false, add: false, del: false, search: true }, {}, {}, {}, {
multipleSearch: true,
multipleGroup: true,
recreateFilter: true
});
});
</script>
</head>
<body>
<table id="list2"></table>
<div id="pager2"></div>
</body>
</html>
I see that you use the code from my old answer.
The error "jqGrid postData.filters is undefined" undefined can be easy fixed by adding the lines
if (postData.filters == null) {
return;
}
inside of modifySearchingFilter
before the line var filters = $.parseJSON(postData.filters);
.
Additional important error in your code is the usage of datatype: "json"
instead of datatype: "local"
. The option datatype: "json"
means that the data fro the grid will be loaded via Ajax request to the URL specified by url
parameter.
One more error is the usage of data: jsonData
instead of data: jsonData.Employees
. It's important to understand that the value of data
parameter have to be an array.
One more remark: I strictly recommend you to use no special characters in the name
property of colModel
(currently you have name: "Emp ID"
). The value of name
property will be used as id
of some internal elements of the grid, but space will by used by jQuery and by CSS as delimiter and as meta-character (see here for example). So I would recommend you to change name: "Emp ID"
to name: "EmpId"
for example to have in the future less problems.
The fixed demo you will fined here. It uses the following code
$(function () {
"use strict";
var jsonData = {
"Employees": [
{
"EmpId": 1.0,
"Name": "Anubhav",
"Gender": "Male",
"Department": "DEVELOPMENT",
"Company": "SOPRA",
"Salary": 100000
},
{
"EmpId": 2.0,
"Name": "Shailesh",
"Gender": "Male",
"Department": "DEVELOPMENT",
"Company": "SOPRA",
"Salary": 10000
},
{
"EmpId": 3.0,
"Name": "Deepak",
"Gender": "Male",
"Department": "SALES",
"Company": "ROQUETTE",
"Salary": 20000
},
{
"EmpId": 4.0,
"Name": "Seema",
"Gender": "Female",
"Department": "PURCHASE",
"Company": "ROQUETTE",
"Salary": 25000
}
]
},
$grid = $("#list2"),
myDefaultSearch = "cn",
getColumnIndexByName = function (columnName) {
var cm = $(this).jqGrid("getGridParam", "colModel"), i, l = cm.length;
for (i = 0; i < l; i += 1) {
if (cm[i].name === columnName) {
return i; // return the index
}
}
return -1;
},
modifySearchingFilter = function (separator) {
var i, l, rules, rule, parts, j, group, str, iCol, cmi, filters,
cm = $(this).jqGrid("getGridParam", "colModel"),
postData = $(this).jqGrid("getGridParam", "postData");
if (postData.filters == null) {
return;
}
filters = $.parseJSON(postData.filters);
if (filters && filters.rules !== undefined && filters.rules.length > 0) {
rules = filters.rules;
for (i = 0; i < rules.length; i++) {
rule = rules[i];
iCol = getColumnIndexByName.call(this, rule.field);
cmi = cm[iCol];
if (iCol >= 0 &&
(((cmi.searchoptions === undefined || cmi.searchoptions.sopt === undefined) &&
rule.op === myDefaultSearch) ||
(typeof (cmi.searchoptions) === "object" &&
$.isArray(cmi.searchoptions.sopt) &&
cmi.searchoptions.sopt.length > 0 &&
cmi.searchoptions.sopt[0] === rule.op))) {
// make modifications only for the "contains" operation
parts = rule.data.split(separator);
if (parts.length > 1) {
if (filters.groups === undefined) {
filters.groups = [];
}
group = {
groupOp: "OR",
groups: [],
rules: []
};
filters.groups.push(group);
for (j = 0, l = parts.length; j < l; j++) {
str = parts[j];
if (str) {
// skip empty "", which exist in case of two separaters of once
group.rules.push({
data: parts[j],
op: rule.op,
field: rule.field
});
}
}
rules.splice(i, 1);
i--; // to skip i++
}
}
}
postData.filters = JSON.stringify(filters);
}
},
dataInitMultiselect = function (elem) {
setTimeout(function () {
var $elem = $(elem), id = elem.id,
inToolbar = typeof id === "string" && id.substr(0, 3) === "gs_",
options = {
selectedList: 2,
height: "auto",
checkAllText: "all",
uncheckAllText: "no",
noneSelectedText: "Any",
open: function () {
var $menu = $(".ui-multiselect-menu:visible");
$menu.width("auto");
return;
}
},
$options = $elem.find("option");
if ($options.length > 0 && $options[0].selected) {
$options[0].selected = false; // unselect the first selected option
}
if (inToolbar) {
options.minWidth = "auto";
}
$elem.multiselect(options);
$elem.siblings("button.ui-multiselect").css({
width: inToolbar ? "98%" : "100%",
marginTop: "1px",
marginBottom: "1px",
paddingTop: "3px"
});
}, 50);
};
$grid.jqGrid({
datatype: "local",
data: jsonData.Employees,
colNames: ["Emp ID", "Name", "Department", "Company", "Salary"],
colModel: [
{ name: "EmpId", sorttype: "integer", key: true },
{ name: "Name" },
{
name: "Department",
width: 160,
align: "center",
edittype: "select",
editoptions: {
value: "DEVELOPMENT:DEVELOPMENT;SALES:SALES;PURCHASE:PURCHASE",
defaultValue: "DEVELOPMENT",
multiple: true
},
stype: "select",
searchoptions: {
sopt: ["eq", "ne"],
value: "DEVELOPMENT:DEVELOPMENT;SALES:SALES;PURCHASE:PURCHASE",
attr: { multiple: "multiple", size: 4 },
dataInit: dataInitMultiselect
}
},
{ name: "Company" },
{ name: "Salary", sorttype: "integer", formatter: "integer" }
],
cmTemplate: { editable: false },
rowNum: 10,
rowList: [10, 20, 100],
pager: "#pager2",
height: "auto",
viewrecords: true,
gridview: true,
ignoreCase: true,
rownumbers: true,
cellEdit: true,
cellsubmit: "clientArray",
editurl: "clientArray",
sortname: "EmpId",
caption: "CDDI Sample Grid",
beforeRequest: function () {
modifySearchingFilter.call(this, ",");
}
});
$grid.jqGrid("filterToolbar", {
searchOperators: true,
stringResult: true,
searchOnEnter: true,
defaultSearch: myDefaultSearch
});
$grid.jqGrid("navGrid", "#pager2", { edit: false, add: false, del: false }, {}, {}, {}, {
multipleSearch: true,
multipleGroup: true,
recreateFilter: true
});
});
这篇关于jqGrid postData.filters是未定义的的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!