jQuery学习笔记——jqGrid的使用记录(实现分页、搜索功能)

jqGrid 是一个用来显示网格数据的jQuery插件,通过使用jqGrid可以轻松实现前端页面与后台数据的ajax异步通信。

一、要引用的文件

要使用jqGrid,首先页面上要引入如下css与js文件。

1、css

<link href="/css/ui.jqgrid.css" rel="stylesheet" type="text/css" />

2、js

  <script src='/Scripts/js/jquery-2.0.3.min.js' type="text/javascript"></script>
  <script src='/Scripts/js/jqGrid/jquery.jqGrid.min.js' type="text/javascript"></script>
  <script src='/Scripts/js/jqGrid/i18n/grid.locale-en.js' type="text/javascript"></script>

二、使用要点说明

1、获取值

(1)、获取单个id

获取行号,有这种方式:

var rowid = $("#grid-table").jqGrid("getGridParam", "selrow");

但是经过实际验证,这种方式不可行,当选中行,再点击同一行会出现获取不到行号的情况。

最后先在js最外部定义一个变量selId,然后使用如下代码在选中行时赋值:

onSelectRow: function (rowid, status) {
    selId = rowid;  //给最外层的selId赋值
  }

(2)、获取多个选中行的id

var ids=$('#gridTable').jqGrid('getGridParam','selarrrow');

其输出格式是逗号分隔的id,如:

1,2,3,4,5

(3)、获得所有行的ID数组

var ids = $("jqgridtableid").jqGrid('getDataIDs');

(4)、获取行数据

如果想获取选择的行的数据,只要传入rowId即可,如下:

var rowData = $('#gridTable').jqGrid('getRowData',rowId);

而这个rowData是一个对象,如果要获取选择的行的这个对象的属性值,如name的值,需如下:

var Name= rowData.name;

(5)、获取单元格数据

var celldata = $("jqgridtableid").jqGrid('getCell',id,colnum);

(6)、设定行选中

  //设定选中行,可设定多行选中:
  $("jqgridtableid").jqGrid('setSelection',id1);
  $("jqgridtableid").jqGrid('setSelection',id2);

2、自定义分页、数据交互

何谓自定义?就是允许你用你自己喜欢的js对象与后端做数据交互。如jsonReader。

如果这个地方的Id设置错了,那么jqGrid就会自动以行号作为Id,这样会影响删除的。如果根据Id来删,很有可能删错行。

jsonReader: {
    id: "Id", //相当于设置主键
    root: "JsonArray",    //Json数据
    total: "TotalPage",   //总页数
    page: "CurrentPage",  //当前页
    records: "TotalRecord",//总记录数
    repeatitems: false
  },

这样一来,对于数据表格,在C#中,我可以用一个泛型类,就能够与jqGrid表格进行交互(其中,包括了分页信息,数据内容)。

/// <summary>
 /// 分页ViewModel
 /// </summary>
 public class jQGrid<T> where T : class
 {
  public jQGrid()
  { }

  /// <summary>
  /// 带4个参数的构造函数
  /// </summary>
  /// <param name="rows">每页显示行数</param>
  /// <param name="currentPage">当前页</param>
  /// <param name="totalRecord">结果总记录数</param>
  /// <param name="jsonArray">JSON数据</param>
  public jQGrid(int rows, int currentPage, int totalRecord, IList<T> jsonArray)
  {
   TotalPage = this.CalculateTotalPage(rows, totalRecord);
   CurrentPage = currentPage;
   TotalRecord = totalRecord;
   JsonArray = jsonArray;
  }

  public int TotalPage { get; set; }
  public int CurrentPage { get; set; }
  public int TotalRecord { get; set; }
  public IList<T> JsonArray { get; set; }

  /// <summary>
  /// 根据每页显示数与总记录数计算出总页数
  /// </summary>
  /// <param name="rows">每页显示数</param>
  /// <param name="totalRecord">结果总记录数</param>
  /// <returns></returns>
  public int CalculateTotalPage(int rows, int totalRecord)
  {
   return Convert.ToInt32(Math.Ceiling((double)totalRecord / (double)rows));
  }
 }

3、搜索的实现

搜索的实现主要通过jqGrid的postData像服务器端传递参数。

$("#btnSearch").click(function () {
    var rules = "";
    $("#multipleSearchDialog").each(function (i) {
      $(".div-padding :input").each(function () {
        if ($(this).val()) {
          rules += '"' + $(this).attr("name") + '":"' + $(this).val() + '"';
        }
      })
    });
  ParamJson = '{' + rules + '}';
  var postData = $("#grid-table").jqGrid("getGridParam", "postData");
  $.extend(postData, { Param: ParamJson });
  $("#grid-table").jqGrid("setGridParam", { search: true }).trigger("reloadGrid", [{ page: 1}]); //重载JQGrid
  });

搜索功能主要通过postData向服务器端传递数据。后端获取参数从而进行处理:

Dictionary<string, string> DicParam = new Dictionary<string, string>();
  string Param = Convert.ToString(Request["Param"]);
  if (!string.IsNullOrEmpty(Param))
  {
    System.Web.Script.Serialization.JavaScriptSerializer sr = new System.Web.Script.Serialization.JavaScriptSerializer();
    DicParam = sr.Deserialize(Param, typeof(Dictionary<string, string>)) as Dictionary<string, string>;
  }

这样就获取到了查询参数的键值对,至于参数怎么用,一般都是用于sql的where子句。

三、更多jqGrid配置属性说明

1、属性


参数名称

类型

描述

默认值

是否可以被修改

ajaxGridOptions

object

对ajax参数进行全局设置,可以覆盖ajax事件:error,complete 和 beforeSend

空值


ajaxGridOptions

object

对ajax参数进行全局设置

空值


ajaxSelectOptions

object

对ajax的select参数进行全局设置,设置editoptions跟searchoptions 参数的select属性值

空值


altclass

String

用于表格行交替变色的class属性。你可以定义自己的class来替代默认值。只有当altRows属性设置为true时,该属性才起作用

ui-priority-secondary

是,但需要重新加载

altRows

boolean

设置表格是否允许行交替变色值

false

是,需重新加载

autoencode

boolean

当为 ture 时对url进行编码

false


autowidth

boolean

如果为ture时,则当表格在首次被创建时会根据父元素比例重新调整表格宽度。如果父元素宽度改变,为了使表格宽度能够自动调整则需要实现函数:setGridWidth

false


caption

String

定义表格名称

空值

否,但是可以用api修改

cellLayout

integer

定义了单元格padding + border 宽度。通常不必修改此值。初始值为5,paddingLef?2+paddingRight?2+borderLeft?1=5

5


cellEdit

boolean

启用或者禁用单元格编辑功能

false


cellsubmit

String

定义了单元格内容保存位置:“remote”,“clientArray”

‘remote'


cellurl

String

单元格提交的url

空值


colModel

array

对显示列属性的设置,是一个数组对象。常用到的属性:name 列显示的名称;index 传到服务器端用来排序用的列名称;width 列宽度;align 对齐方式;sortable 是否可以排序

空值


colNames

array[]

放置列名称的数组,必须与colModel大小相同

空数组


datastr

String

xmlstring或者jsonstring

空值


datatype

string

从服务器端返回的数据类型,(表格期望接收的数据类型)。可选类型:xml,xmlstring,json,local,function

xml


deselectAfterSort

boolean

只有当datatype为local时起作用。当排序时不选择当前行

true


direction

string

表格中文字的显示方向,从左向右(ltr)或者从右向左(rtr)。

ltr


editurl

string

定义对form编辑时的url

空值


emptyrecords

string

当返回的数据行数为0时显示的信息。只有当属性 viewrecords 设置为ture时起作用

在语言包中


ExpandColClick

boolean

当为true时,点击展开行的文本时,treeGrid就能展开或者收缩,不仅仅是点击图片

true


ExpandColumn

string

指定那列来展开tree grid,默认为第一列,只有在treeGrid为true时起作用

空值


footerrow

boolean

当为true时,会在翻页栏之上增加一行

false


forceFit

boolean

当为ture时,调整列宽度不会改变表格的宽度。当shrinkToFit 为false时,此属性会被忽略

false


gridstate

string

定义当前表格的状态:'visible' or 'hidden'

visible


gridview

boolean

构造一行数据后添加到grid中,如果设为true则是将整个表格的数据都构造完成后再添加到grid中,但treeGrid, subGrid, or afterInsertRow 不能用

false


height

mixed

表格高度,可以是数字,像素值或者百分比

150


hiddengrid

boolean

当为ture时,表格不会被显示,只显示表格的标题。只有当点击显示表格的那个按钮时才会去初始化表格数据。只有当caption 属性不为空而且hidegrid为ture时才起作用

false


hidegrid

boolean

启用或者禁用控制表格显示、隐藏的按钮,只有当caption 属性不为空时起效

true


hoverrows

boolean

当为false时mouse hovering会被禁用

false


jsonReader

array

描述json期望数据格式的数组。
 

lastpage

integer

只读属性,定义了总页数

0


lastsort

integer

只读属性,定义了最后排序列的索引,从0开始

0


loadonce

boolean

如果为ture则数据只从服务器端抓取一次,之后所有操作都是在客户端执行,翻页功能会被禁用

false


loadtext

string

当请求或者排序时所显示的文字内容

Loading....


loadui

string

当执行ajax请求时要干什么。disable禁用ajax执行提示;enable默认,当执行ajax请求时的提示; block启用Loading提示,但是阻止其他操作

enable


mtype

string

请求的类型:(“POST” or “GET”)

GET


multikey

string

只有在multiselect设置为ture时起作用,定义使用那个key来做多选。shiftKeyaltKeyctrlKey

空值


multiboxonly

boolean

只有当multiselect = true.起作用,当multiboxonly 为ture时只有选择checkbox才会起作用,

false


multiselect

boolean

定义是否可以多选

false


multiselectWidth

integer

当multiselect为true时设置multiselect列宽度

20


page

integer

设置初始的页码

1


pager

mixed

指定分页栏对象,必须为一个有效的html元素。可以是'pager', '#pager', jQuery('#pager').推荐用'#pager'

空值


pagerpos

string

指定分页栏的位置

center


pgbuttons

boolean

是否显示翻页按钮

true


pginput

boolean

是否显示跳转页面的输入框

true


pgtext

string

当前页信息

语言包中设置


prmNames

array

Default valuesprmNames: {page:“page”,rows:“rows”, sort: “sidx”,order: “sord”, search:“_search”, nd:“nd”, npage:null} 当参数为null时不会被发到服务器端

none


postData

array

此数组内容直接赋值到url上,参数类型:{name1:value1…}

空array


reccount

integer

只读属性,定义了grid中确切的行数。通常情况下与records属性相同,但有一种情况例外,假如rowNum=15,但是从服务器端返回的记录数是20,那么records值是20,但reccount值仍然为15,而且表格中也只显示15条记录。

0


recordpos

string

定义了记录信息的位置: left, center, right

right


records

integer

只读属性,定义了返回的记录数

none


recordtext

string

显示记录数信息。{0} 为记录数开始,{1}为记录数结束。 viewrecords为ture时才能起效,且总记录数大于0时才会显示此信息

语言包


resizeclass

string

定义一个class到一个列上用来显示列宽度调整时的效果

空值


rowList

array[]

一个数组用来调整表格显示的记录数,此参数值会替代rowNum参数值传给服务器端。如果为空则不显示,设置格式:[10,20,30]。

[]


rownumbers

boolean

如果为ture则会在表格左边新增一列,显示行顺序号,从1开始递增。此列名为'rn'.

false


rowNum

integer

设置表格中显示的记录数,参数会被自动传到后台。如果此参数设为10,但是从服务器端返回15条记录,那么在表格中只会显示10条记录。如果设为-1则禁用此检查

20


rownumWidth

integer

如果rownumbers为true,则可以设置column的宽度

25


savedRow

array

只读属性,只用在编辑模式下保存数据

空值


scroll

boolean or integer

创建一个动态滚动的表格,当为true时,翻页栏被禁用,使用垂直滚动条加载数据,且在首次访问服务器端时将加载所有数据到客户端。当此参数为数字时,表格只控制可见的几行,所有数据都在这几行中加载

false


scrollOffset

integer

设置垂直滚动条宽度

18


scrollrows

boolean

当为true时让所选择的行可见

false


selarrrow

array-[]

只读属性,用来存放当前选择的行

empty array []


selrow

string

只读属性,最后选择行的id

null


shrinkToFit

boolean

此属性用来说明当初始化列宽度时候的计算类型,如果为ture,则按比例初始化列宽度。如果为false,则列宽度使用colModel指定的宽度

true


sortable

boolean

是否可排序

false


sortname

string

排序列的名称,此参数会被传到后台

空字符串


sortorder

string

排序顺序,升序或者降序(asc or desc)

asc


subGrid

boolean

是否使用suggrid

false


subGridModel

array-[]

subgrid模型

empty array


subGridType

mixed

如果为空则使用表格的dataType

null


subGridUrl

string

加载subgrid数据的url,jqGrid会把每行的id值加到url中

空值


subGridWidth

integer

subgrid列的宽度

20


toolbar

array

表 格的工具栏。数组中有两个值,第一个为是否启用,第二个指定工具栏位置(相对于body layer),如:[true,”both”] 。工具栏位置可选值:“top”,”bottom”, “both”. 如果工具栏在上面,则工具栏id为“t_”+表格id;如果在下面则为 “tb_”+表格id;如果只有一个工具栏则为 “t_”+表格id

[false,'']


totaltime

integer

只读属性,计算加载数据的时间。目前支持xml跟json数据

0


treedatatype

mixed

数据类型,通常情况下与datatype相同,不会变

null


treeGrid

boolean

启用或者禁用treegrid模式

false


treeGridModel

string

treeGrid所使用的方法

nested


treeIcons

array

树的图标,默认值:{plus:'ui-icon-triangle-1-e',minus:'ui-icon-triangle-1-s',leaf:'ui-icon-radio-off'}
 

treeReader

array

扩展表格的colModel且加在colModel定义的后面
 

tree_root_level

numeric

root元素的级别,

0


url

string

url

null


userData

array

从request中取得的一些用户信息

empty array


userDataOnFooter

boolean

当为true时把userData放到底部,用法:如果userData的值与colModel的值相同,那么此列就显示正确的值,如果不等那么此列就为空

false


viewrecords

boolean

是否要显示总记录数

false


viewsortcols

array

定 义排序列的外观跟行为。数据格式:[false,'vertical',true].第一个参数是说,是否都要显示排序列的图标,false就是只显示当 前排序列的图标;第二个参数是指图标如何显示,vertical:排序图标垂直放置,horizontal:排序图标水平放置;第三个参数指单击功 能,true:单击列可排序,false:单击图标排序。说明:如果第三个参数为false则第一个参数必须为ture否则不能排序
 

width

number

如果设置则按此设置为主,如果没有设置则按colModel中定义的宽度计算

none


xmlReader

array

对xml数据结构的描述
 

url

获取数据的地址

datatype

从服务器端返回的数据类型,默认xml。可选类型:xml,local,json,jsonnp,script,xmlstring,jsonstring,clientside

mtype

ajax提交方式。POST或者GET,默认GET

colNames

列显示名称,是一个数组对象。

colModel

对显示列属性的设置,是一个数组对象。常用到的属性:name 列显示的名称;index 传到服务器端用来排序用的列名称;width 列宽度;align 对齐方式;sortable 是否可以排序

pager

定义翻页用的导航栏,必须是有效的html元素。翻页工具栏可以放置在html页面任意位置

rowNum

在grid上显示记录条数,这个参数是要被传递到后台

rowList

一个下拉选择框,用来改变显示记录数,当选择时会覆盖rowNum参数传递到后台

sortname

默认的排序列。可以是列名称或者是一个数字,这个参数会被提交到后台

viewrecords

定义是否要显示总记录数

caption

表格名称

2、事件

事件 参数 描述
afterInsertRow rowid 
rowdata 
rowelem
此事件发生在每次插入行后
rowid 为插入的行ID
rowdata 是被插入行的数据数组。格式为name:value对,name在colModel定义
rowelem 是应答元素。xml为xml行,json为所有行数据。
注意:若gridview 为true,此事件不会发生
beforeRequest none 此事件发生在任何数据请求前,但当datatype为function时不发生。
beforeSelectRow rowid, e 此事件发生在用户点击行,选中该行前。
rowid 为行的ID,e为事件对象
该事件将返回布尔值true(行被选中)或false(行未被选中)。
gridComplete none 此事件发生在表格所有数据装入和进程完成后。与datatype参数及排序分页等无关。
loadBeforeSend xhr,
settings
此事件发生在XMLHttpRequest被发送前,用于修改对象属性(如headers)。 xhr 为XMLHttpRequest对象。
loadComplete data 此事件发生在每个服务器请求后。xhr 为XMLHttpRequest对象。
loadError xhr,
status,
error
此事件在请求失败时发生。事件有3个参数:
xhr 为XMLHttpRequest对象;
Satus 为错误类型描述;error 为错误对象。
onCellSelect rowid,
iCol, 
cellcontent,
e
此事件在点击表格特定单元格时发生。
rowid 为行ID;iCol 为列索引;
cellcontent 为单元格中内容;
e 点击事件对象。
ondblClickRow rowid, 
iRow, 
iCol, 
e
此事件发生在行双击后发生。
rowid为行ID;iRow 为行索引(勿与rowid混淆);
iCol为列索引;
e 为事件对象。
onHeaderClick gridstate 此事件发生在点击显示或隐藏表格后发生(hidegrid为true) gridstate为表格状态,有visible和hidden两个值
onPaging pgButton 此事件发生在点击page button后,填充数据前,及用户输入一个与当前页页码不同的新页码并回车时。
onRightClickRow rowid, 
iRow, 
iCol, 
e
此事件发生在右击行后。(此事件在Opera浏览器中无效)
rowid为行ID;iRow为行索引(勿与rowid混淆)
iCol为列索引;
e为事件对象
onSelectAll aRowids,
status
此事件发生在点击标题的复选框时发生(multiselect为true)
aRowids 选定行ID的数组(哪些行的复选框与头复选框相同)
status 头复选框的选定的布尔值,true为选中,false为
onSelectRow rowid,
status
此事件发生在行点击后
rowid 为行ID;
status  为选择状态。当multiselect为true时使用,当行被选中时返回true;为选中时返回false。
onSortCol index,
iCol,
sortorder
此事件发生在列排序被点击之后,数据排序前
index 为colModel 中定义的索引名iCol 为列的索引号
sortorder 为新的排序方式,asc或desc
resizeStart event, index 此事件发生在列被重新定义宽度时。 event 为事件对象;index 为在colModel 中定义的列索引。
resizeStop newwidth, index 此事件发生在列被重新定义宽度后。
newwidth 为新的列宽度;index 为在colModel 中定义的列索引。
serializeGridData postData 通过此事件可以序列化传递给ajax请求的的数据。此事件将返回一个以序列化的数据。若有自定义的数据(如JSON字符串、XML字符串)要发给服务器时,可使用该事件。

3、方法

方法 参数 返回值 描述
addJSONData data none 用传递的data(数组)填充网格。用法:假如我们从web服务器获得的数据(jsonresponse),则
var mygrid = jQuery(”#”+grid_id)[0];
var myjsongrid = eval(”(”+jsonresponse.responseText+”)”); 
mygrid.addJSONData(myjsongrid); 
myjsongrid = null; 
jsonresponse =null; 
将填充网格。当然,myjsongrid中的数据在传递到addJSONData之前可以被操作。
addRowData rowid,
data, 
position, 
srcrowid
true on success, 
false otherwise
插入一新行,rowid 为新行的ID,data(数组)为新行数据,position为新行插入的位置(first为表头,last为表尾,srcrowid指定偏移位置)。Data数组的格式为:{name1:value1,name2: value2…} ,name为colModel指定的名称。
addXmlData data none 用传入的data填充网格。用法:假如我们从web服务器获得数据
(xmlresponse),则 var mygrid = jQuery(”#”+grid_id)[0]; 
mygrid.addXmlData(xmlresponse.responseXML); 
将填充网格。当然,xmlresponse中的数据在传递到addXmlData之前可以被操作。
clearGridData clearfooter jqGrid object 清除网格中当前装入的数据,如果clearfooter 参数为true,则清除网格最后一行数据。
delRowData rowid true on success, 
false otherwise
删除id = rowid的行。但不会删除服务器上的数据。
footerData action,
data, 
format
jqGrid object 此方法获得或设置网格底部数据。
action – 可设置为get(缺省)或set。 Get从底部返回name:value对象(name为colModel中的名称)。此时其他两个参数无效。 
Set将data数组(对象)设置到底部。Data为colName中的名称和值对。
format – 缺省为true,表示设置时使用formatter (如果colModel中已定义)。false表示不使用formatter
getCell rowid, 
iCol
cell content 返回id = rowid行,column = iCol列的内容。 iCol可以是列的索引或colName中定义的名称。在编辑行或列时不能使用该方法,此时返回的不是当前值,而是原始值。
getCol colname, returntype, mathoperation array[] or value 返回列值数组。
colname 可以是列的索引值或colModel中的名称。returntype 确定返回数组的类型,为false(缺省)时,数组只包含值。为true时为对象数组,格式为{id:rowid, value:cellvalue},id为行的id, cellvalue为单元格的值。如 [{id:1,value:1},{id:2,value:2}…] 
mathoperation为可选参数,可以是sum、avg和count。若此参数进行了有效设置,则返回计算后的值,若无效,则返回空数组。
getDataIDs none array[] 返回当前网格显示数据的ID数组。无数据时返回空数组。
getGridParam name mixed value 返回请求的参数的值。name 是options 数组中的名称,若为设置则options被返回。
getInd rowid,
rowcontent
mixed 当rowcontent 设置为false(缺省)时,返回id= rowid行的索引值。若rowcontent设置为true,则返回整行。若为找到rowid则返回false。
getLocalRow rowid row object Return the row data from the local array stored in data parameter when the datatype is local
getRowData rowid or none array{} 返回id = rowid行的数据数组。格式为name:value对,name为colModel中的名称,value为该行的值。未找到返回空数组。在行或列编辑时此方法不可用,此时返回的不是当前值,而是原始值。
若rowid为设置,则返回网格中所有数据数组。
hideCol colname
or
[colnames]
jqGrid object 根据colname或colnames数组给定的列名隐藏相应的列,列名必须是colModel中定义的名称。表格的宽度不会改变。
remapColumns permutation, updateCells, keepHeader none 调整列的显示顺序。permutation指定调整后的顺序,如 [1,0,2] 表示第一列在第二位显示。若updateCells 设置为true,列数据将重新排序。若keepHeader 设置为true,header单元格将重新排序。
resetSelection none jqGrid object 选择(反选)行。多选择模式下同样可用。
setCaption caption jqGrid object 设置新的表头文字。若表头为隐藏,将显示。
setCell rowid,
colname, 
data, 
class, 
properties, 
forceup
jqGrid object 修改单元格的值、类或样式。其中:
rowid为行ID;colname为列名(可以是从0开始的列的索引值);
data 设置的内容,若为空,class若为字符串,将使用addClass为列加入一个类,若为数组,将直接加入CSS中;properties 设置单元格属性。
setGridParam object jqGrid object 设置一个特定的参数。
有些参数需trigger(“reloadGrid”)才能生效。注意这个方法可以覆盖事件。名称(name:value对)为选项数组中的名称。 
setGridHeight new_height jqGrid object 动态设置网格高度。只能对单元格的高度进行设置而不是网格。new_height 可以是像素、百分比或auto。
setGridWidth new_width,
shrink
jqGrid object 动态设置网格宽度。new_width 为新宽度的像素值;
shrink(true或false)作用同shrinkToFit。若不设置,则使用shrinkToFit设置。
setLabel colname, 
data, 
class, 
properties
jqGrid object 设置指定列标题文字、属性和类:
colname 为列名,可以是从0开始的列索引;
data 为标题文字,为空则不修改;
class 若为字符串,则为类名,若为数组,则直接写入CSS;
properties 为标题文字的属性。
setRowData rowid,
data, 
cssprop
true on success, 
false otherwise
更新rowid指定行的数据(使用数组)。
Data数组的格式为: {name1:value1,name2: value2…} 。name为colModel中描述的名称,value为新值。cssprop若为字符串,将使用addClass为行添加类;若为数组对象,则直接加入CSS中。将data设置为false的情况下,可设置属性和类名
setSelection rowid,
onselectrow
jqGrid object 选择或反选id = rowid指定的行。若onselectrow设置为true (缺省) 则触发onSelectRow事件,否则不触发。
showCol colname jqGrid object 显示colname 指定的列。若colname为字符串,只显示指定的列,若colname为数组 [“name1”,”name2”] 则显示name1和name2列, name必须是colModel中的名称。宽度不变。
trigger(“reloadGrid”) none none 按当前设置重新加载网格。若datatype为xml或json,将从服务器重新请求数据。此方法适用于一个已建立的网格。注意不会改变表头,也就是说改变colModel将没有作用。你可用gridUnload,使用新colModel来重新加载。
updateColumns none none 在拖拽表格时,同步网格宽度。用法:
var mygrid=jQuery(”#grid_id”)[0];
mygrid.updateColumns();

四、问题记录

1、IE9下jQgrid一直出现水平滚动条的问题。

解决:是因为jqGrid会在IE下出现border与padding造成宽度过大引起的,增加此属性可解决:

cellLayout:0

此时当页面缩放摆100%时,已经不显示滚动条,但是缩放比例不为100%时,依然会显示水平滚动条,终极解决方案为更改ui.jqgrid.css样式:

.ui-jqgrid .ui-jqgrid-bdiv{ overflow-x: hidden; }

如果还是不行,还有一个方法:

 $(grid_selector).closest(".ui-jqgrid-bdiv").css({ 'overflow-x': 'hidden' });

当然你也可以直接修改样式.ui-jqgrid-bdiv增加overflow-x:hidden;

2、自定义操作列。

jqGrid默认的自定义编辑列,只能设置编辑按钮与删除按钮。并且图标基本上都很难控制,如果想自己实现自己的自定义编辑列,可以如下操作:

在actions列的formatoptions项,增加此行:

name: 'myac', index: '', width: 80, fixed: true, sortable: false, resize: false,
     formatter: 'actions',
     formatoptions: {
     keys: true,
     delbutton:false,
     delOptions: { recreateForm: true, beforeShowForm: beforeDeleteCallback },
     formatter:"actionFormatter"
   },

然后在页面开始处增加如下代码:

 $.extend($.fn.fmatter, {
  actionFormatter: function(cellvalue, options, rowObject) {
   var retVal = "显示在原来编辑按钮的按个地方的代码";
   return retVal;
  }
 } );

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 基于jquery实现的类似百度搜索的输入框自动完成功能

    废话不多说,直观的看一下: 实现这个功能需要服务端配合.客户端通过脚本来展示从服务端取得的数据. 先看客户端的HTML: 复制代码 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">  <html xmlns="http://www.w3.org/1999/x

  • jquery实现静态搜索功能(可输入搜索文字)

    效果图: 代码如下: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>jquery实现静态搜索功能</title> <!-- 最新版本的 Bootstrap 核心 CSS 文件 --> <link rel="stylesheet" href="https://cdn.bootcss.com/boo

  • jQuery实现搜索页面关键字的功能

    在一篇文章中查找关键字,找到后高亮显示. 具体代码: <html> <head> <title>Search</title> <style type="text/css"> p { border:1px solid black;width:500px;padding:5px;} .highlight { background-color:yellow; } </style> </head> <bo

  • 基于jquery的仿百度搜索框效果代码

    先看看整个的效果图:图一: 图二: 图三: 图四: 大概的效果图就这样,接下来直接看源码页面: 复制代码 代码如下: <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="autoSearch._Default" %> <!DOCTYPE html PUBLIC "-//W3C//DT

  • Jquery插件仿百度搜索关键字自动匹配功能

    本文实例为大家分享了Jquery搜索关键字自动匹配功能的实现代码,供大家参考,具体内容如下 jQuery AutoComplete 是一个基于jQuery实现搜索关键字自动匹配提示的插件,该插件可扩展性强,表现性能优越,方便整合到自己的项目中使用:兼容IE 6.0+, FF 2+, Safari 2.0+, Opera 9.0+, and Chrome 1.0+ 等主流浏览器. 下面是具体的使用方法: 1.使用设置 首页,要把插件的js代码嵌入到你自己的项目中去. 复制代码 代码如下: <scr

  • jQuery实现的仿百度,仿谷歌搜索下拉框效果示例

    本文实例讲述了jQuery实现的仿百度,仿谷歌搜索下拉框效果.分享给大家供大家参考,具体如下: 运行效果图如下: 完整实例代码如下: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3c.org/TR/1999/REC-html401-19991224/loose.dtd"> <html> <head> <title>

  • jquery zTree异步加载、模糊搜索简单实例分享

    本文实例为大家讲解了jquery zTree树插件的基本使用方法,具体内容如下 一.节点模糊搜索功能:搜索成功后,自动高亮显示并定位.展开搜索到的节点. 二.节点异步加载:1.点击展开时加载数据:2.选中节点时加载数据. 前台代码如下: <script type="text/javascript"> //ztree设置 var setting = { view: { fontCss: getFontCss }, check: { enable: true }, data:

  • Jquery Easyui搜索框组件SearchBox使用详解(19)

    本文实例为大家分享了Jquery Easyui搜索框组件的实现代码,供大家参考,具体内容如下 加载方式 Class加载 <input id="ss" class="easyui-searchbox" style="width:300px" data-options="prompt:'Please Input Value',menu:'#box'"> </input> <div id="b

  • 利用jQuery实现可输入搜索文字的下拉框

    先看效果   功能:点击下拉框输入框时,自动显示下面的下拉列表,而且是根据输入框中输入的搜索添加,自动在后台查找,然后传到前台,展现页面. 用的的js: 复制代码 代码如下: var $xialaSELECT; $(document).ready(function(){ initXialaSelect(); initSearch(); }); var temptimeout=null; var query=""; function searchDev(key){ //if(key ==

  • 基于jQuery实现页面搜索功能

    jQuery实现页面搜索,搜索筛选用户输入的内容! HTML: <div class="table"> <table> <tr id="theader"> <th>姓名</th> <th>性别</th> <th>联系方式</th> </tr> <tr> <td>客服</td> <td>女</td

随机推荐