• jqGrid使用记录


    一、要引用的文件

      要使用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: '', 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;
            }
        } );

      更多学习地址:

      1、http://polaris.blog.51cto.com/1146394/260176/

      2、http://blog.csdn.net/yangbobo1992/article/details/7929772

      3、http://blog.csdn.net/yangbobo1992/article/category/1227409

      4、http://blog.csdn.net/gengv/article/details/5758321

      5、http://hi.baidu.com/baitly002/item/2a735e27ac5b7945469962bf

      6、http://blog.csdn.net/seng3018/article/details/7756433

      7、http://blog.csdn.net/gaofang2009/article/details/5845592

      8、http://www.cnblogs.com/jes_shaw/archive/2011/01/18/1938742.html

      9、http://www.coding123.net/article/20130704/jqGrid-predefined-formatter.aspx

      10、http://mj4d.iteye.com/blog/1634857

      11、http://hi.baidu.com/zhanglp/item/26a7f6fc5e39e855c9f33790

      12、http://hi.baidu.com/feifan3211/item/c5831f44158761a5df2a9fc1

      13、http://blog.csdn.net/yangbobo1992/article/details/7929772

      14、http://www.2cto.com/kf/201111/109891.html

      15、http://luocb1980.iteye.com/blog/1762997

      16、http://blog.csdn.net/zhcj3672/article/details/6944955

  • 相关阅读:
    spring读取配置文件内容并自动注入
    xshell免费下载安装使用
    cas sso原理
    sql两列相除,保留n位小数
    mysql 报zone什么的错误
    mysql union出错: "Every derived table must have its own alias"
    mysql jdbc操作
    sql 对某列取值进行if判断
    Python深入:02浅拷贝深拷贝
    Python基础:22__slots__类属性
  • 原文地址:https://www.cnblogs.com/kissdodog/p/3875992.html
Copyright © 2020-2023  润新知