jQuery插件jqGrid动态获取列和列字段的方法


Posted in Javascript onMarch 03, 2017

本文实例讲述了jQuery插件jqGrid动态获取列和列字段的方法。分享给大家供大家参考,具体如下:

1、问题背景

jqGrid表格插件,利用自身方法获取表格的表头和表格字段;获取列名和列字段名显示在弹窗里,用复选框进行勾选

2、实现源码

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8" />
    <title>jqGrid动态获取列和列字段</title>
    <link rel="stylesheet" href="css/ui.jqgrid.css" rel="external nofollow" />
    <link rel="stylesheet" href="css/ui.jqgrid-bootstrap-ui.css" rel="external nofollow" />
    <link rel="stylesheet" href="css/bootstrap.css" rel="external nofollow" />
    <link rel="stylesheet" href="css/bootstrap-theme.css" rel="external nofollow" />
    <link rel="stylesheet" href="css/jquery-ui.css" rel="external nofollow" />
    <link rel="stylesheet" href="css/jquery-ui.theme.css" rel="external nofollow" />
    <script type="text/javascript" src="js/jquery-1.11.0.min.js" ></script>
    <script type="text/javascript" src="js/jquery-ui.js"></script>
    <script type="text/javascript" src="js/jquery.jqGrid.min.js" ></script>
    <script type="text/javascript" src="plugins/grid.setcolumns.js"></script>
    <style>
      th{
        border: 1px solid #ABABAB;
        line-height: 20px;
        vertical-align: middle;
      }
      td{
        line-height: 20px;
      }
    </style>
    <script>
      $(document).ready(function(){
        $("#jqTable").jqGrid({
          url:"data/student.json",
          height:380,
          datatype:"json",
          colNames:["序号","姓名","年龄","性别","QQ号","电话","地址"],
          colModel:[{
            name : 'id',
            index : 'id',
            label : '序号',
            width : 60,
            align:'center'
          },{
            name : 'name',
            index : 'name',
            label : '姓名',
            width : 120,
            align:'center'
          },{
            name : 'age',
            index : 'age',
            label : '年龄',
            width : 120,
            align:'center'
          },{
            name : 'sex',
            index : 'sex',
            label : '性别',
            width : 120,
            edittype : "select",
            formatter : 'select',
            editoptions : {
              value :'0:男;1:女;'
            },
            align:'center'
          },{
            name : 'qq',
            index : 'qq',
            label : 'QQ号',
            width : 120,
            align:'center'
          },{
            name : 'phone',
            index : 'phone',
            label : '电话',
            width : 120,
            align:'center'
          },{
            name : 'address',
            index : 'address',
            label : '地址',
            width : 200,
            align:'center'
          }],
          sortname : "id",
          sortorder : "desc",
          viewrecords : true,
          rownumbers:true,
          autowidth:true,
          jsonReader : {
            repeatitems : false
          }
        });
        var dialog = $("#dialog-column").dialog({
          autoOpen :false,
          modal : true,
          resizable : true,
          height: "auto",
          width: 400,
          align:'center',
          buttons: {
            "确定": function() {
              $(this).dialog( "close" );
            },
            "关闭": function() {
              $(this).dialog( "close" );
            }
          }
        });
        $("#column").button().on("click", function() {
          dialog.dialog("open");
          //获取列名
          var colNames=$("#jqTable").jqGrid('getGridParam','colNames');
          //获取列字段
          var colModel=$("#jqTable").jqGrid('getGridParam','colModel');
          var table = "";
          var newColumnName = [];
          var newColumnValue = [];
          for (var i=0;i<colNames.length;i++)
          {
            var columnHidden = colModel[i].hidden;
            var columnName = colModel[i].name;
            if(columnHidden==false && columnName != "rn")
            {
              newColumnName.push(colNames[i]);
              newColumnValue.push(columnName);
            }
            console.info(columnName);
          }
          for(var j=0;j<newColumnName.length;j++)
          {
            if(j%5==0)
            {
              table += "<tr>";
            }
            table += "<td><input type='checkbox' id='"+newColumnValue[j]+"' name='column' checked='checked'><label for='"+newColumnValue[j]+"'>"+newColumnName[j]+"</label></td>";
            if((j+1)%5==0)
            {
              table += "</tr>";
            }
          }
          $("#tableColumn").empty().append(table);
        });
      });
    </script>
  </head>
  <body>
    <div>
      <table id="jqTable" class="table"></table>
    </div>
    <div>
      <button id="column" type="button">显示</button>
    </div>
    <div id="dialog-column" title="设置列">
      <table id="tableColumn" style="width: 100%; height: 100px;">
      </table>
    </div>
  </body>
</html>

3、实现结果

(1)初始化

jQuery插件jqGrid动态获取列和列字段的方法

(2)单击按钮

jQuery插件jqGrid动态获取列和列字段的方法

希望本文所述对大家jQuery程序设计有所帮助。

Javascript 相关文章推荐
根据选择不同的下拉值出现相对应的文本输入框
Aug 01 Javascript
javascript模拟地球旋转效果代码实例
Dec 02 Javascript
js使用ajax读博客rss示例
May 06 Javascript
JS实现从网页顶部掉下弹出层效果的方法
Aug 06 Javascript
Validform+layer实现漂亮的表单验证特效
Jan 17 Javascript
JS设置随机出现2个数字的实例代码
Jul 19 Javascript
IE9 elementUI文件上传的问题解决
Oct 17 Javascript
JavaScript继承的特性与实践应用深入详解
Dec 30 Javascript
Layui弹出层 加载 做编辑页面的方法
Sep 16 Javascript
layui--select使用以及下拉框实现键盘选择的例子
Sep 24 Javascript
详解Vue后台管理系统开发日常总结(组件PageHeader)
Nov 01 Javascript
electron+vue实现div contenteditable截图功能
Jan 07 Javascript
AngularJS表格样式简单设置方法示例
Mar 03 #Javascript
AngularJS表格添加序号的方法
Mar 03 #Javascript
JS实现双击内容变为可编辑状态
Mar 03 #Javascript
jquery表单验证实例仿Toast提示效果
Mar 03 #Javascript
JavaScript的for循环中嵌套一个点击事件的问题解决
Mar 03 #Javascript
JavaScript控制输入框中只能输入中文、数字和英文的方法【基于正则实现】
Mar 03 #Javascript
angularjs实现下拉列表的选中事件示例
Mar 03 #Javascript
You might like
PHP写的加密函数,支持私人密钥(详细介绍)
2013/06/09 PHP
ThinkPHP多语言支持与多模板支持概述
2014/08/22 PHP
举例详解PHP脚本的测试方法
2015/08/05 PHP
PHP生成可点击刷新的验证码简单示例
2016/05/13 PHP
JavaScript高级程序设计(第3版)学习笔记8 js函数(中)
2012/10/11 Javascript
Ext JS 4实现带week(星期)的日期选择控件(实战二)
2013/08/21 Javascript
制作jquery遮罩层效果导航菜单代码分享
2013/12/25 Javascript
JavaScript中的toUTCString()方法使用详解
2015/06/12 Javascript
jquery彩色投票进度条简单实例演示
2020/07/23 Javascript
基于NodeJS+MongoDB+AngularJS+Bootstrap开发书店案例分析
2017/01/12 NodeJs
jQuery+ajax实现动态添加表格tr td功能示例
2018/04/23 jQuery
Vue 中axios配置实例详解
2018/07/27 Javascript
详解Vue+axios+Node+express实现文件上传(用户头像上传)
2018/08/10 Javascript
详解如何使用node.js的开发框架express创建一个web应用
2018/12/20 Javascript
实例分析编写vue组件方法
2019/02/12 Javascript
ES6知识点整理之模块化的应用详解
2019/04/15 Javascript
前端Vue项目详解--初始化及导航栏
2019/06/24 Javascript
javascript 对象 与 prototype 原型用法实例分析
2019/11/11 Javascript
[00:12]DAC2018 no[o]ne亮相SOLO赛 他是否如他的id一样无人可挡?
2018/04/06 DOTA
python实现图片变亮或者变暗的方法
2015/06/01 Python
Python实现股市信息下载的方法
2015/06/15 Python
使用Python机器学习降低静态日志噪声
2018/09/29 Python
python数据归一化及三种方法详解
2019/08/06 Python
详解pycharm连接不上mysql数据库的解决办法
2020/01/10 Python
基于python 等频分箱qcut问题的解决
2020/03/03 Python
python中使用you-get库批量在线下载bilibili视频的教程
2020/03/10 Python
python报错: 'list' object has no attribute 'shape'的解决
2020/07/15 Python
Luxplus瑞典:香水和美容护理折扣
2018/01/28 全球购物
幼师专业毕业生自荐信
2013/09/29 职场文书
小学教师的个人自我鉴定
2013/10/26 职场文书
个人安全生产承诺书
2014/05/22 职场文书
税务干部群众路线教育实践活动自我剖析材料
2014/09/21 职场文书
卖车协议书范本4篇
2014/10/01 职场文书
2015中秋节晚会主持词
2015/07/01 职场文书
JS实现简单控制视频播放倍速的实例代码
2021/04/18 Javascript
PostgreSQL出现死锁该如何解决
2022/05/30 PostgreSQL