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


Posted in Javascript onNovember 09, 2016

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来做多选。shiftKey,altKey,ctrlKey 空值
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 为插入的行IDrowdata 是被插入行的数据数组。格式为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;
  }
 } );

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

Javascript 相关文章推荐
获取URL地址中的文件名和参数的javascript代码
Sep 02 Javascript
判断对象是否Window的实现代码
Jan 10 Javascript
Raphael一个用于在网页中绘制矢量图形的Javascript库
Jan 08 Javascript
JavaScript window.location对象
Nov 14 Javascript
jQuery中element选择器用法实例
Dec 29 Javascript
JS实现点击事件统计的简单实例
Jul 10 Javascript
用AngularJS来实现监察表单按钮的禁用效果
Nov 02 Javascript
Jquery uploadify 多余的Get请求(404错误)的解决方法
Jan 26 Javascript
基于jQuery的$.getScript方法去加载javaScript文档解析
Nov 08 jQuery
基于Vue的ajax公共方法(详解)
Jan 20 Javascript
vue单页缓存存在的问题及解决方案(小结)
Sep 25 Javascript
node.js使用yargs处理命令行参数操作示例
Feb 11 Javascript
jQuery Ztree行政地区树状展示(点击加载)
Nov 09 #Javascript
Bootstrap模态框水平垂直居中与增加拖拽功能
Nov 09 #Javascript
使用 bootstrap modal遇到的问题小结
Nov 09 #Javascript
H5移动端图片压缩上传开发流程
Nov 09 #Javascript
微信小程序 网络API Websocket详解
Nov 09 #Javascript
微信小程序 网络API 上传、下载详解
Nov 09 #Javascript
微信小程序 网络API发起请求详解
Nov 09 #Javascript
You might like
php in_array 函数使用说明与in_array需要注意的地方说明
2010/04/13 PHP
PHP读取CSV大文件导入数据库的实例
2017/07/24 PHP
Alliance vs AM BO3 第二场2.13
2021/03/10 DOTA
Notify - 基于jquery的消息通知插件
2011/10/18 Javascript
jQuery.fn和jQuery.prototype区别介绍
2013/10/05 Javascript
jquery列表拖动排列(由项目提取相当好用)
2014/06/17 Javascript
15位和18位身份证JS校验的简单实例
2016/07/18 Javascript
js实现带三角符的手风琴效果
2017/03/01 Javascript
js实现3D图片环展示效果
2017/03/09 Javascript
VueJS如何引入css或者less文件的一些坑
2017/04/25 Javascript
JS图片轮播与索引变色功能实例详解
2017/07/06 Javascript
微信小程序实现文字跑马灯效果
2020/05/26 Javascript
原生js实现省市区三级联动代码分享
2018/02/12 Javascript
浅谈js闭包理解
2019/04/01 Javascript
vue 移动端注入骨架屏的配置方法
2019/06/25 Javascript
javascript合并两个数组最简单的实现方法
2019/09/14 Javascript
[02:56]DOTA2亚洲邀请赛 VG出场战队巡礼
2015/02/07 DOTA
python实现从文件中读取数据并绘制成 x y 轴图形的方法
2018/10/14 Python
Python实现获取系统临时目录及临时文件的方法示例
2019/06/26 Python
flask框架jinja2模板与模板继承实例分析
2019/08/01 Python
Python3简单爬虫抓取网页图片代码实例
2019/08/26 Python
python SocketServer源码深入解读
2019/09/17 Python
Python django搭建layui提交表单,表格,图标的实例
2019/11/18 Python
一个入门级python爬虫教程详解
2021/01/27 Python
阿联酋电子产品购物网站:Menakart
2017/09/15 全球购物
RealTek面试题
2016/06/28 面试题
Servlet如何得到客户端机器的信息
2014/10/17 面试题
行政文秘岗位职责范本
2014/02/10 职场文书
保研推荐信
2014/05/09 职场文书
文明礼貌演讲稿
2014/05/12 职场文书
党的群众路线对照检查材料思想汇报
2014/09/25 职场文书
2015年民兵整组工作总结
2015/07/24 职场文书
校园安全主题班会
2015/08/12 职场文书
《全神贯注》教学反思
2016/02/22 职场文书
Django 实现jwt认证的示例
2021/04/30 Python
Python中的socket网络模块介绍
2022/07/23 Python