jqgrid中文帮助文档网址:http://blog.mn886.net/jqGrid/
jqgrid:用来做什么?
jqgrid是web端前台表格控件,用它可以轻松将数据格式化显示,前后台用过ajax进行互动。
jqgrid:原理?
jqGrid是典型的B/S架构,服务器端只是提供数据管理,客户端只提供数据显示。

实例:

$(document).ready(function()
{
    initPlsfList();
});

//初始化grid列表
function initPlsfList(){
    //缓存表列数组,key 为页面元素的name ,value 对应数据库中的字段
    var cellArray = new Array();
    cellArray["zoneID"] ="ZONE_ID";
    cellArray["factorPG"] ="FACTOR_PG";
    cellArray["factorQG"] ="FACTOR_QG";
    cellArray["factorPL"] ="FACTOR_PL";
    cellArray["factorQL"] ="FACTOR_QL";
    cellArray["valid"] ="VALID";  

    var caseID = '${caseID}';
    $("#plsfList").jqGrid({
        url:"<c:url value='/lfc/powerlsfactor/queryData?caseID="+caseID+"' />",
        datatype: "json",
        mtype:"POST",
        height: "auto",
        width: "auto",
        colNames:[
                  'id',
                  "<fmt:message key='case.valid'/>",
                  "<fmt:message key='zone'/>",
                  "<fmt:message key='pasf'/>",
                  "<fmt:message key='pisf'/>",
                  "<fmt:message key='lasf'/>",
                  "<fmt:message key='lisf'/>",
                  'modeID'
                  ],
        colModel:[
                  {name:'id',index:'id', width:100,hidden:true},
                  {name:'valid',index:'valid', width:100,editable:true,
                      formatter:formatValid,
                      editable:true,edittype:'checkbox',
                      editoptions:{value:'1:0',defaultValue:'1'}
                  },
                  {name:'zoneName',index:'zoneName', width:150,editable:true},
                  {name:'factorPG',index:'factorPG', width:100,editable:true},
                  {name:'factorQG',index:'factorQG', width:100,editable:true},
                  {name:'factorPL',index:'factorPL', width:100,editable:true},
                  {name:'factorQL',index:'factorQL', width:100,editable:true},
                  {name:'caseID',index:'caseID', width:100,hidden:true},
                 ],
        rowNum:10,
        rowList:[10,20,30],
        pager: '',
        cellEdit:true,
        viewrecords: true,
        jsonReader: { repeatitems : false, id: "id" },
        viewsortcols:[false,'horizontal',false],
        sortable:false,
        sortorder:"asc",
        sortname:"id",
        multiselect: true,
        cellurl:"<c:url value='/lfc/powerlsfactor/save'/>",
        cellsubmit: 'remote',
        gridComplete: function() {
            var $selecAll = $("#cb_plsfList");
            var cb_title = "<fmt:message key='select.all' bundle='${commonResources}'/>" ;
            if($selecAll){
                $selecAll.attr("title",cb_title);
            }
            //设置全选checkbox title
            var rowIds = jQuery("#plsfList").jqGrid('getDataIDs');
            for(var k=0; k<rowIds.length; k++) {
               var curRowData = jQuery("#plsfList").jqGrid('getRowData', rowIds[k]);
               var curChk = $("#"+rowIds[k]+"").find(":checkbox");
               //curChk.attr('title', curRowData.modeName);   //给checkbox赋予额外的属性值
            }  

        },
        onSortCol:function(index,iCol,sortorder){
            return false ;
        },
        ondblClickRow: function (rowid,iRow,iCol,e) {
            /*var $plsfList = $("#plsfList");
            if (isRowNeedSave($plsfList)){
                showMessage("请先保存");
            }else{
                $("#operate").val("update");
                newrowid = rowid ;
                $plsfList.setGridParam({cellEdit:false});
                $plsfList.jqGrid('editRow', rowid, true);
                //确定按钮可用
                $("#confirm_btn").attr("disabled",false);  

            }*/
        },
        beforeSubmitCell:function(rowid, cellname, value, iRow, iCol){
         //列提交前的拦截方法
            var $plsfList = $("#plsfList") ;
            var $editUrl = '<c:url value='/lfc/powerlsfactor/save'/>' ;
         //设置列提交的url。updateCellName:要编辑的列名 ;updateCellValue :是编辑的值
            $editUrl = addParamToUrl($editUrl,'updateCellName',iCol == 3 ? cellArray['zoneID'] :cellArray[cellname]);
            $editUrl = addParamToUrl($editUrl,'updateCellValue',iCol == 3 ? $("#zone_id").val():value);
         //给jqgrid 从新设置cellurl 值
            $plsfList.setGridParam({cellurl:$editUrl});
            return false ;
        },
        afterEditCell:function(rowid, cellname, value, iRow, iCol){
        //动态修改lie时,当列 变为可修改状态时,给列add一个button,且列中元素不可编辑,点击button  弹出一个模态窗口,可以选择元素 ,赋值给grid当前编辑列中单行表单域中.
            $("#"+rowid+" input[type='checkbox']").attr("checked",value == "<fmt:message key='case.valid'/>" ? true:false);
            if(iCol==3){
                $("#irowNum").val(rowid);
                var $data = $("#"+rowid +">td"); //获取这个行里所有的td元素,即:获取所有子元素
                $zoneInput = $data.find("input").eq("1") ;
                $zoneInput.css("width","100px");
                $zoneInput.attr("disabled",true);
                $zoneInput.after("<input type='button' value='选择' onclick='fnCallDialogForEidt()' />");
            }
        }  

    });  

//grid添加新的一行
var newrowid ;
function addRow()
{
    $("#operate").val("");
    var selectedId = $("#plsfList").jqGrid("getGridParam", "selrow");
    var ids = jQuery("#plsfList").jqGrid('getDataIDs');
    //获得当前最大行号(数据编号)
    var rowid = Math.max.apply(Math,ids);
    //获得新添加行的行号(数据编号)
    newrowid = rowid+1;
    var dataRow = {
        id: "",
        valid:"",
        zoneID:'',
        factorPG:'',
        factorQG:'',
        factorPL:'',
        factorQL:'',
        caseID:''
    };      

    //将新添加的行插入到第一列
    $("#plsfList").jqGrid("addRowData", newrowid, dataRow, "first");
    //设置grid单元格不可编辑
    $("#plsfList").setGridParam({cellEdit:false});
    //设置grid单元格可编辑
    $('#plsfList').jqGrid('editRow', newrowid, false);
    //确定按钮可用
    $("#confirm_btn").attr("disabled",false);
    //给添加的列加选择按钮
    var $zoneInput = $("#"+newrowid+"_zoneName");
    $zoneInput.attr("disabled",true).css("width",100);
    $zoneInput.after("<input type='button' value='选择' onclick='fnCallDialogForEidt()' />");  

}  

function insertPlsf(){
    var $plsfList = $("#plsfList") ;
    var $operate = $("#operate").val();
    //设置grid单元格可编辑
    $plsfList.setGridParam({cellEdit:true});
    //设置grid行不可编辑
    //$plsfList.jqGrid('editRow', newrowid, false);
    //拼接请求的url
    var url = '<%=basePath%>'+"/lfc/powerlsfactor/save" ;
    var $params = $plsfList.find("input[id^="+newrowid+"]");
    var $check_val = $params.eq(0).is(':checked') ? 1:0;
    url = addParamToUrl(url,'valid',$check_val);
    url = addParamToUrl(url,'zoneID',$("#zone_id").val());
    url = addParamToUrl(url,'factorPG',$params.eq(2).val());
    url = addParamToUrl(url,'factorQG',$params.eq(3).val());
    url = addParamToUrl(url,'factorPL',$params.eq(4).val());
    url = addParamToUrl(url,'factorQL',$params.eq(5).val());  

    var $caseID = $("#caseID").val();
    url = addParamToUrl(url,'caseID',$caseID);  

    $.ajax({url:url,type:"post",timeout:5000,
            success:function(data){
                showMessage(data);
                reloadGrid();
            }
    });
    //将新添加行号 初始为空
    newrowid = '' ;
    //确定按钮不可用
    $("#confirm_btn").attr("disabled",true);
}  

//格式zone列输出内容
function formatZone(cellvalue, options, rowObject){
    if(cellvalue == 0){
        return 0;
    }else if(cellvalue == 1){
        return 1;
    }else if(cellvalue == 2){
        return 2;
    }else{
        return 3;
    }
}  

function isRowNeedSave($jqgrid){
    var $editTr = $jqgrid.find("tr[editable=1]") ;
    var flag = false ;
    if ( $editTr && $editTr.length > 0){
        flag = true ;
    }
    return flag ;
}  

function cancel(){
    reloadGrid();
    //确定按钮不可用
    $("#confirm_btn").attr("disabled",true);
    //设置grid单元格可编辑
    $("#plsfList").setGridParam({cellEdit:true});
    //设置grid单元格可编辑
    $('#plsfList').jqGrid('editRow', newrowid, true);
}  

function fnCallDialogForEidt(){
    //获得当前行号(数据编号)
    var returnValue = "";
    returnValue = window.showModalDialog("<c:url value='/element/zone/query?caseID="+$("#caseID").val()+"' />",window,"");
    if(returnValue==""||returnValue==null)
        return;
    var $plsfList = $("#plsfList");
    var $params = $plsfList.find("input[id$='zoneName']");
    var names = returnValue.split(",");
    $params.eq(0).val(names[1]);
    $("#zone_id").val(names[0]);
}  

jqgrid学习笔记(转载)的更多相关文章

  1. jQgrid学习笔记

    jQgrid学习笔记

  2. jqGrid 学习笔记--数据异步加载方法(转)

    var commonQuery = '../importantInfoReport/pageQueryImportantInfoReport.action?type=0'; jQuery(" ...

  3. jqGrid学习笔记(二)

    本节介绍jqGrid其他的使用方法,主要是一些基本操作,特殊的数据显示等. 1 刷新jqGrid数据. 常用到刷新jqGrid数据的情况是,在用到查询的时候,根据查询条件,请求数据,并刷新jqGrid ...

  4. jqGrid学习笔记(一)

    3.2.body中的代码 <!-- jqGrid table list4 --> <table id="list4"></table> < ...

  5. ASP.NET MVC and jqGrid 学习笔记 6-增删改操作

    程序结构: Member.cs CRUD.cshtml CRUD.js HomeController 一.Model public class Member { [Key] public int No ...

  6. ASP.NET MVC and jqGrid 学习笔记 5-添加数据

    据介绍,jqgrid有3种编辑数据的方式: Cell Editing 只允许修改某一个单元格内容 Inline Editing 允许在jqGrid中直接修改某一行的数据 Form Editing 弹出 ...

  7. ASP.NET MVC and jqGrid 学习笔记 4-排序

    排序(Sorting)分为两种:客户端排序和服务端排序 客户端排序的意思是把数据从数据库里一次性全部提取出来,然后在客户端进行排序,以后每次点击标题进行排序时,就不会给服务端传递请求了.这个“一次性” ...

  8. ASP.NET MVC and jqGrid 学习笔记 3-如何从数据库获得数据

    实际应用中,大部分都是从数据库里获得数据,所以先建立一个数据库,Database first 或者Code first都可以,这里用Code first. 一.Model public class M ...

  9. ASP.NET MVC and jqGrid 学习笔记 2-如何从本地获得数据

    上回说到jqgrid的基本配置,同时演示了显示数据的一种方法——datatype: "local".这种方法是从本地获取的,确切地说是在前端页面的javascript里写的硬编码. ...

随机推荐

  1. 备忘录--关于线程和IO知识

    因为自己还在出差中,没时间深入学习,最近工作里又有对一些技术的思考,所以这里记录下来,等回去有时间可以按照这个思路进行学习,这里主要起到备忘的作用. 1.线程难学难在我们没有理解操作系统里的线程设计机 ...

  2. 企业IT管理员IE11升级指南【2】—— Internet Explorer 11 对Adobe Flash的支持

    企业IT管理员IE11升级指南 系列: [1]—— Internet Explorer 11增强保护模式 (EPM) 介绍 [2]—— Internet Explorer 11 对Adobe Flas ...

  3. Alljoyn瘦客户端库介绍(官方文档翻译)

    Alljoyn瘦客户端库介绍(上) 1.简介 本文档对AllJoynTM瘦客户端的核心库文件(AJTCL)进行了详尽的介绍.本文档介绍了系统整体架构,AllJoyn框架结构,并着重于介绍如何将嵌入式设 ...

  4. .Net组件程序设计之对象生命周期

    .Net组件程序设计之对象生命周期 .NET 垃圾回收 IDisposable() Using语句 .NET 垃圾回收 是CLR管理着垃圾回收器,垃圾回收器监控着托管堆,而我们使用的对象以及系统启动是 ...

  5. CVTE实习求职经历

    今天,听到有好多同学最近要去面试CVTE这家企业,于是呢,准备将自己的经历写上来,给大家一个参考,希望能够大家一次帮助. 一.整体感觉 首先呢,先讲一下我个人对这家企业的整体感觉吧. 1. 第一次 对 ...

  6. [nodemon] Internal watch failed: watch ENOSPC错误解决办法

    运行环境:Ubuntu 16.04, WebStorm 2016.1.3, node.js v0.12.5, nodemon 1.9.2 在WS自带的终端输入nodemon server.js启动项目 ...

  7. 《Entity Framework 6 Recipes》中文翻译系列 (36) ------ 第六章 继承与建模高级应用之TPC继承映射

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 6-12  TPC继承映射建模 问题 你有两张或多张架构和数据类似的表,你想使用TP ...

  8. web应用中使用JavaMail发送邮件

    现在很多的网站都提供有用户注册功能, 通常我们注册成功之后就会收到一封来自注册网站的邮件.邮件里面的内容可能包含了我们的注册的用户名和密码以及一个激活账户的超链接等信息.今天我们也来实现一个这样的功能 ...

  9. CocoaPods pod 安装、更新慢解决方法

    使用CocoaPods来添加第三方类库,无论是执行pod install还是pod update都卡在了Analyzing dependencies不动了,令人甚是DT. 每一次都忘记现在自己记录一下 ...

  10. [转]Linux常用命令

    系统信息arch 显示机器的处理器架构(1) uname -m 显示机器的处理器架构(2) uname -r 显示正在使用的内核版本 dmidecode -q 显示硬件系统部件 - (SMBIOS / ...