项目中经常会用到表格编辑控件,网上也有不少,但是确实没有完全符合我要求的,

自己写一个吧!

1.该控件支持 数据显示列,文本编辑列,选择列,下拉列,索引列,删除列 六种列类型

2.支持全键盘操作,自定义键位 包括:列焦点切换,行焦点切换,新建行,数据保存(默认 上,下,左,右 键操作)

3.丰富的事件,绝大多数的客户端操作都能触发无刷新后台事件

4.支持统计运算,可自定义运算插件

5.兼容 Ie,chorme,firefox等绝大多数主流浏览器

下载地址:http://files.cnblogs.com/dint/WebGridEditor.rar

客户端调用代码:

<table id='table1' border='1' class='hgeTableCss' cellspacing='0' cellpadding='0' style='width:700px'>
      	<tr>
      		<th style='width:20px'></th>
      	  <th>ID</th>
      	  <th>Name</th>
      	  <th>Sex</th>
      	  <th>Address</th>
      	  <th>Content</th>
      	  <th>delete</th>
      	</tr>
      	<tr>
      		<td></td>
      		<td> 111</td>
      		<td> </td>
      		<td> </td>
      		<td> </td>
      		<td> </td>
      		<td></td>
        </tr>
      </table>

   <script type='text/javascript'>
	 var editor1;
    	 var myrows=[
    	   ['1','2','3','bbb','5'],
    	   ['1','2','3','ccc','5'],
    	   ['1','2','3','aaa','5'],
    	   ['1','2','3','ccc','5'],
    	   ['1','2','3','bbb','5']
    	  ];
      editor1=new HtGridEditor('table1');
      editor1.bIndex=true;
      editor1.datas.rows=myrows;
      editor1.vWidth='500px';
      editor1.Columns=[
      {type:1,defv:'111',funk:true}
      ,{type:1,defv:'dingtao',change:true}
      ,{type:1,defv:'hello',nexk:true}
      ,{type:2,drpItems:[{dtext:'aaa',dvalue:'aaa'},
      	{dtext:'bbb',dvalue:'bbb'},
      	{dtext:'ccc',dvalue:'ccc'}],defv:'bbb',change:true
      	}
      ,null
      ,{type:10,defv:'del'}
      ];
      editor1.Footers=[{index:1,colspan:2,text:'TotalA:{0},TotalB:{1}',console:['SUM-2','SUM-0']}
      ,{index:3,text:'合计'}];
editor1.bDownNew=true;
      editor1.fixedHeader=true;     editor1.ShowEditor();</script>

  

直接上效果图了

1.表头不固定,无表尾

表头不固定 有表尾

表头固定 无表尾

表头固定 有表尾

服务器端处理请求的代码 (C#)

 using System;
 using System.Collections;
 using System.Configuration;
 using System.Data;
 using System.Web;
 using System.Web.Security;
 using System.Web.UI;
 using System.Web.UI.HtmlControls;
 using System.Web.UI.WebControls;
 using System.Web.UI.WebControls.WebParts;
 using Newtonsoft.Json;

 namespace HTGridEditorTest
 {
     public partial class _Default : System.Web.UI.Page
     {
         protected void Page_Load(object sender, EventArgs e)
         {
             string hgeAjax = Request["HGE_AJAX_VER"];//HGE_AJAX_VER HtGridEditor Ajax版本
             if ((hgeAjax != null) && (hgeAjax == "1_0_0"))//HtGridEditor请求的数据 版本号 一般通过这个标识判断是否为 HtGridEditor的ajax请求
             {
                 if (Request["method"] == "REFRESH")
                 {
                     Response.Clear();
                     HgeCommand c = new HgeCommand();
                     c.cmd = "refresh";
                     ][];
                     Random r = new Random();
                     ; i < ; i++)
                     {
                         data[i] = ];
                         data[i][] = (i + ).ToString();
                         data[i][] = ).ToString();
                         data[i][] = r.Next().ToString();
                         data[i][] = "ccc";
                         data[i][] = "ddd";
                     }
                     c.data = data;
                     Response.Write(JsonConvert.SerializeObject(c));
                     Response.End();
                 }
                 else if (Request["method"] == "REMOVED")//method 操作类型 REMOVED删除行 CREATED新建行
                 {
                     Response.Clear();
                     HgeCommand c = new HgeCommand();
                     c.cmd = "message";
                     c.data = "delete one row "+Request["OROW"];
                     HgeCommand[] cs = ];
                     cs[] = c;
                     Response.Write(JsonConvert.SerializeObject(cs));
                     Response.End();
                 }
                 else if (Request["method"] == "CREATED")
                 {
                     Response.Clear();
                     string str = Request["OROW"];//新建的行的值
                     string[] arr = JsonConvert.DeserializeObject<string[]>(str);
                     string resps = "";
                     ; i < arr.Length; i++) resps += arr[i] + ",";
                     HgeCommand c = new HgeCommand();
                     c.cmd = "message";
                     c.data = "create a new row data:" + resps.Trim(',');
                     HgeCommand[] cs = ];
                     cs[] = c;
                    // Response.Write(JsonConvert.SerializeObject(cs));
                     //Response.End();
                 }
                 else if (Request["method"] == "CHANGED")//选择行改变
                 {
                     Response.Clear();
                     string str = Request["NROW"];
                     string[] arr = JsonConvert.DeserializeObject<string[]>(str);
                     string resps = "";
                     ; i < arr.Length; i++) resps += arr[i] + ",";
                     HgeCommand c = new HgeCommand();
                     c.cmd = "message";
                     c.data ="select row changed data:" + resps.Trim(',');
                     HgeCommand[] cs = ];
                     cs[] = c;
                     Response.Write(JsonConvert.SerializeObject(cs));
                     Response.End();
                 }
                 else if (Request["method"] == "SAVED")//保存数据
                 {
                     Response.Clear();
                     string[][] arr = JsonConvert.DeserializeObject<string[][]>(Request["SVDATA"]);
                     string resps = "";
                     ; i < arr.Length; i++)
                     {
                         resps += "[";
                         ; j < arr[i].Length; j++)
                         {
                             resps += arr[i][j] + ",";
                         }
                         resps = resps.Trim(',') + "],";
                     }
                     HgeCommand c = new HgeCommand();
                     c.cmd = "message";
                     c.data = "select row saved data:" + resps.Trim(',');
                     HgeCommand[] cs = ];
                     cs[] = c;
                     Response.Write(JsonConvert.SerializeObject(cs));
                     Response.End();
                 }
                 else if(Request["method"]=="TXTCHANGED"){//文本改变
                     Response.Clear();
                     HgeCommand c = new HgeCommand();
                     c.cmd = "message";
                     c.data ="input changed in row " + Request["IROW"]
                         + " and cell " + Request["ICELL"] + " and value " + Request["VALUE"]+" and row value "+Request["OROW"];
                     HgeCommand[] cs = ];
                     cs[] = c;
                     Response.Write(JsonConvert.SerializeObject(cs));
                     Response.End();
                 }
                 else if (Request["method"] == "FOCUSNEXT")//当前编辑文本因为按enter失去焦点
                 {
                     Response.Clear();
                     HgeCommand c = new HgeCommand();
                     c.cmd = "message";
                     c.data = "focus next in row " + Request["IROW"]
                          + " and cell " + Request["ICELL"] + " and value " + Request["VALUE"] +" and row value "+ Request["OROW"];
                     HgeCommand[] cs = ];
                     cs[] = c;
                     Response.Write(JsonConvert.SerializeObject(cs));
                     Response.End();

                     //服务器端可以使用如下的命令控制客互端的行为 命令的详细说明见 HtGridEditor.js
                     /*HgeCommand c = new HgeCommand();
                     c.cmd="message";
                     c.data=" hello HtGridEditor !";*/

                     /*HgeCommand c = new HgeCommand();
                     c.cmd = "selectopitons";
                     c.icell = "4";
                     c.selectvalue = "5555";
                     string[][] options=new string[6][];
                     options[0] = new string[2] { "EEEE", "1111" };
                     options[1] = new string[2] { "FFFF", "2222" };
                     options[2] = new string[2] { "GGGG", "3333" };
                     options[3] = new string[2] { "HHHH", "4444" };
                     options[4] = new string[2] { "IIII", "5555" };
                     options[5] = new string[2] { "JJJJ", "6666" };
                     c.data = options;
                     c.select_cache = "cache";*/

                     /*HgeCommand c = new HgeCommand();
                     c.cmd = "setcell";
                     c.data = new string[3] { "1", "2", "hello test setcell command" };*/

                     /*HgeCommand c = new HgeCommand();
                     c.cmd = "setcells";
                     string[][] cells = new string[3][];
                     cells[0] = new string[3] {"1","2","test setcells command"};
                     cells[1] = new string[3] {"2","4","aaa"};
                     c.data = cells;*/

                     /*HgeCommand c = new HgeCommand();
                     c.cmd = "setrow";
                     c.data = new string[5]{"2", "cell a", "cell b", "cell c", "bbb"};*/

                     /*HgeCommand c = new HgeCommand();
                     c.cmd = "setrowedit";
                     c.data = "4";*/

                     /*HgeCommand c = new HgeCommand();
                     c.cmd = "setcellfocus";
                     c.data = "2";*/

                     /*HgeCommand c = new HgeCommand();
                     c.cmd = "newrow";
                     c.data = "focus";*/

                     /*HgeCommand[] cs = new HgeCommand[1];
                     cs[0] = c;
                     Response.Write(JsonConvert.SerializeObject(cs));
                     Response.End();*/

                     //也可以由若干命令组合使用 前端会按顺序执行
                     //如:新建一行 使其获得焦点 且中当前列
                    /* HgeCommand[] cs = new HgeCommand[2];
                     HgeCommand c = new HgeCommand();//新建一行
                     c.cmd = "newrow";
                     c.data = "focus";
                     cs[0] = c;
                     c = new HgeCommand();//使新行的当前列获得焦点
                     c.cmd = "setcellfocus";
                     c.data = Request["ICELL"];
                     cs[1] = c;
                     Response.Write(JsonConvert.SerializeObject(cs));
                     Response.End();*/
                 }
             }
             else
             {

             }

         }

     }
     public class HgeCommand
     {
         public string cmd;
         public string icell;
         public string selectvalue;
         public string select_cache;
         public object data;
     }
 }

javascript - 可编辑表格控件 支持全键盘操作(无JS框架)的更多相关文章

  1. Qt实现表格控件-支持多级列表头、多级行表头、单元格合并、字体设置等

    目录 一.概述 二.效果展示 三.定制表头 1.重写数据源 2.重写QHeaderView 四.设置属性 五.相关文章 原文链接:Qt实现表格控件-支持多级列表头.多级行表头.单元格合并.字体设置等 ...

  2. QRowTable表格控件-支持hover整行、checked整行、指定列排序等

    目录 一.开心一刻 二.嘴一嘴 三.效果展示 四.浅谈实现 五.自定义数据源 1.data函数 2.flags函数 六.自定义视图 1.目的 2.问题分析 七.测试 八.相关文章 原文链接:QRowT ...

  3. QRowTable表格控件(五)-重写表头排序、支持第三次单击恢复默认排序

    目录 一.原生表格 二.效果展示 三.实现方式 1.排序列定制 2.排序交互修改 四.相关文章 原文链接:QRowTable表格控件(五)-重写表头排序.支持第三次单击恢复默认排序 一.原生表格 开发 ...

  4. Qt实现表格树控件-支持多级表头

    目录 一.概述 二.效果展示 三.实现方式 四.多级表头 1.数据源 2.表格 3.QStyledItemDelegate绘制代理 五.测试代码 六.相关文章 原文链接:Qt实现表格树控件-支持多级表 ...

  5. 深入浅出ExtJS 第三章 表格控件

    3.1 表格的特性简介 >.Ext中的表格功能:包括排序/缓存/拖动/隐藏某一列/自动显示行号/列汇总/单元格编辑等实用功能; >.表格由类Ext.grid.GridPanel定义,继承自 ...

  6. QRowTable表格控件(三)-效率优化之-合理使用QStandardItem

    目录 一.开心一刻 二.概述 三.效果展示 四.QStandardItem 1.QStandardItem是什么鬼 2.性能分析 3.QStandardItem使用上的坑 五.相关文章 原文链接:QR ...

  7. QTableView表格控件区域选择-自绘选择区域

    目录 一.开心一刻 二.概述 三.效果展示 四.实现思路 1.绘制区域 2.绘制边框 3.绘制 五.相关文章 原文链接:QTableView表格控件区域选择-自绘选择区域 一.开心一刻 陪完客户回到家 ...

  8. QRowTable表格控件(二)-红涨绿跌

    目录 一.开心一刻 二.概述 三.效果展示 四.任务需求 五.指定列排序 六.排序 七.列对其方式 八.相关文章 原文链接:QRowTable表格控件(二)-红涨绿跌 一.开心一刻 一天,五娃和六娃去 ...

  9. QRowTable表格控件(四)-效率优化之-优化数据源

    目录 一.开心一刻 二.问题分析 三.重写数据源 1.自己存储数据 2.重写data接口 四.比较 五.相关文章 原文链接:QRowTable表格控件(四)-效率优化之-优化数据源 一.开心一刻 一程 ...

随机推荐

  1. PHP 使用 curl_* 系列函数和 curl_multi_* 系列函数进行多接口调用时的性能对比

    在页面中调用的服务较多时,使用并行方式,即使用 curl_multi_* 系列函数耗时要小于 curl_* 系列函数. 测试环境 操作系统:Windows x64 Server:Apache PHP: ...

  2. Matlab中常用机器学习函数

    更多内容请参考http://cn.mathworks.com/help/stats/index.html?s_cid=doc_ftr. Naive Bayes(朴素贝叶斯) Factor = Naiv ...

  3. iOS - + initialize 与 +load

    一.+ initialize 方法和+load 调用时机 首先说一下 + initialize 方法:苹果官方对这个方法有这样的一段描述:这个方法会在 第一次初始化这个类之前 被调用,我们用它来初始化 ...

  4. docker-freebsd-20150625

    http://www.docker.org.cn/book/docker/prepare-docker-1.html https://wiki.freebsd.org/Docker pkg insta ...

  5. 最全的jQuery知识汇总

    本帖最后由 断天涯大虾 于 2016-12-26 10:22 编辑<ignore_js_op> jQuery是什么? jQuery是javascript编写一个可重用的JavaScript ...

  6. sql执行

    一.提高sql执行效率---in与exist . where column in (select * from table where ...) . ...where exists (select ' ...

  7. idea 光标变成粗体且当前文件搜索功能无法使用的问题

    今天安装了idea最新版,安装完成后发现光标变成了粗体,并且快捷键在使用时出现了问题,比如:ctrl+F搜索功能无法使用 经过反复修改配置也无法改善情况,后来一次重启看到下面小窗弹出有关vim的一个提 ...

  8. CSS之元素选择器

    1.后代元素选择器 div p 以空格分隔,表示div的所有后代p元素 2.子元素选择器 div > p 以大于号分隔,表示div的直接子元素 3.相邻兄弟选择器 div  + p 选择紧接在d ...

  9. 学霸数据处理项目之数据处理网页以及后台以及C#代码部分开发者手册

    写在前面,本文将详细介绍学霸数据处理项目中的数据处理网页与后台函数,以及c#代码中每一个方法的意义及其一些在运行方面需要注意的细节,供开发人员使用,开发人员在阅读相关方法说明时请参照相关代码,对于本文 ...

  10. 设置文本框左边显示的View

    效果: