tbl.js div实现的表格控件,完全免费,不依赖jquery
html上现在有比较好用的表格控件是datatable,但是编辑、按钮等部分是收费的,只有基础功能免费。而且尺寸发生变化时需要手工刷新等繁琐操作较多。所以我开发一个免费的供大家使用。
本项目已用于“虚空服务器开发套件”。目前主要支持微软Edge浏览器,Chrome浏览器,其它未测。
tbl.js完全免费,可随意修改,欢迎fork。
tbl.js支持列表样式,增删改查,全表搜索,分组,分页功能,全表编辑,全行编辑,单选,多选,样式定制。
可以嵌入到各种容器中,比如jquery的dialog,tabs中。
版本:0.1beta
提出bug,我会尽快修改。新年不休息。
如果不需要修改样式,可以不加载tbl.css,tbl.js会动态加载样式表。
我们来创建两行表格,从现有的DOM节点构建。
1 html:<html><body><div></div></body></html>
2 new tbl(document.body.children[0],{data:[["row1"],["row2"]]});
将自创建的DOM节点插入到文档body中。
1 var tb = new tbl();
2 with (document.body) { insertBefore(tb.dom, firstChild) };
3 tb.bind([["row1"],["row2"]]);
多个字段的表格,列的宽度用百分比自适应。
1 var tb = new tbl(undefined, {format:[{width:"20%"},{width:"20%"},{width:"20%"},{width:"20%"},{width:"20%"}]});
2 with (document.body) { insertBefore(tb.dom, firstChild) };
3 tb.bind([["row1","data","data","data","data"],["row2","data","data","data","data"]]);
列表样式,最大高度300px,无头部,无标题,无页脚,5条数据,按钮,获取行索引。
这种方式会有隔行的颜色变化,可以修改CSS使样式失效。
1 html:<html><body><div></div></body></html>
2 var tb = new tbl(document.body.children[0], {
3 editable: false, maxheight: "300px", header: false, title: false, footer: false, data: [[1], [2, "remove"], ["nan - not a number", "del"], [4, "del"], [5, "del"]], page_size: 100,
4 format: [
5 { width: "90%", nancenter: true, input: {type:"text"}},
6 { width: "10%", editable:true, input: { type: "button", value:"del", onclick: function () { tb.delete(tb.get_related_rowid(this));}}}
7 ]
8 });
全表编辑,单选,必须选择一行,分页。
我们先初始化一个数据,tbl.js绑定的数据必须是数组。
我期望第二列在任何情况都不能被编辑。
1 var tb_data = [];
2 for (var i = 0; i < 106; i++) {
3 tb_data[i] = [Math.random()>0.5?true:false, Math.random(), "1970-01-01", Math.floor(Math.random()*10), i, 0];
4 }
5 tb_data[i] = "this is group"; i++;
6 tb_data[i] = ["this is text"]; i++;
7 for (; i < 578; i++) {
8 tb_data[i] = [i, Math.random(), "2017-02-01"];
9 }
10 var tb = new tbl(document.body.children[0], {
11 editable:true,select:tbl.single,must_select:true,paging:true,data:tb_data,page_size:15,
12 format: [
13 { width: "5%", input: { type: "checkbox", check: "true" } },
14 { width: "30%", name:"name", uneditable:true },
15 { width: "20%", name:"date", input: { type: "date" } },
16 { width: "10%", name:"select", input: {type:"select", options:[0,1,2,3,4,5,6,7,8,9]} },
17 { width: "20%" },
18 { width: "15%", input: {type:"radio", name:"only"}}
19 ]
20 });
API:
add 末尾添加,添加一行数据必须是数组,非数组会作为组标题文本。
insert 插入数据
bind 绑定新数据源
delete 删除一行
clear 清理
edit 编辑一行,空参数表示编辑整表
select 选择一行
cancel_edit 取消编辑
cancel_select 取消选择
select_change 选择改变函数设置
只读属性:
tbl::selects 已经选择的行
tbl::data 数据
tbl::dom DOM节点
tbl::edits 正在编辑的行,全表编辑不适用
构造选项:
max_height 最大高度,超过将显示滚动条
 page_size 页尺寸
 data 初始化数据
 header 是否显示表头
 footer 是否显示页脚
 info 是否显示信息
 paging 是否显示分页
 title_bar 显示标题条
 title 标题条文本
 search 显示搜索框
 editable  全表编辑
 select 选择的类型:0, 不能选择. 1, 单选. 2, 多选.tbl.single == 1, tbl.multiselect == 2
 select_change 设置选择事件处理函数
 must_select  必须选择一行
 format  列格式
     width 宽度,可以是有效的html宽度。例如:100px or 20%.
     input 用于编辑状态的input节点属性,与html/input属性相同
     name 字段名称,显示在表头
     uneditable 列将不能被编辑
     editable 列将总是编辑状态
     nancenter  非数字居中
项目/源码:
github:https://github.com/FettLuo/tbl.js
tbl.js div实现的表格控件,完全免费,不依赖jquery的更多相关文章
- tbl.js div实现的表格控件,完全免费,no jquery
		
html上现在有比较好用的表格控件是datatable,但是编辑.按钮等部分是收费的,只有基础功能免费.而且尺寸发生变化时需要手工刷新等繁琐操作较多.所以我开发一个免费的供大家使用. 本项目已用于“虚 ...
 - ExtJS4.2学习(九)属性表格控件PropertyGrid(转)
		
鸣谢网址:http://www.shuyangyang.com.cn/jishuliangongfang/qianduanjishu/2013-11-15/178.html ------------- ...
 - Atitit  项目界面h5化静态html化计划---vue.js 把ajax获取到的数据 绑定到表格控件 v2 r33.docx
		
Atitit 项目界面h5化静态html化计划---vue.js 把ajax获取到的数据 绑定到表格控件 v2 r33.docx 1. 场景:应用在项目列表查询场景下1 1.1. 预计初步掌握vue ...
 - 如何在web中实现类似excel的表格控件
		
Execl功能非常强大,内置的很多函数或公式可以大大提高对数据的加工处理能力.那么在web中有没有类似的控件呢?经过一番搜寻,发现handsontable具备了基本的excel功能支持公式,同时能对数 ...
 - 深入浅出ExtJS  第三章 表格控件
		
3.1 表格的特性简介 >.Ext中的表格功能:包括排序/缓存/拖动/隐藏某一列/自动显示行号/列汇总/单元格编辑等实用功能; >.表格由类Ext.grid.GridPanel定义,继承自 ...
 - ExtJS4.2学习(10)分组表格控件--GroupingGrid(转)
		
鸣谢网址:http://www.shuyangyang.com.cn/jishuliangongfang/qianduanjishu/2013-11-17/179.html ------------- ...
 - Ext入门学习系列(五)表格控件(1)
		
上节学习了Ext面板控件,为后面的各个控件学习奠定基础,在此基础上本章将学习网络开发最期待的功能——表格控件. 我们都知道网络编程语言中,除了.net其他的基本没有提供网格控件,而最近的asp.net ...
 - 支持Angular 2的表格控件
		
前端框架一直这最近几年特别火的一个话题,尤其是Angular 2拥有众多的粉丝.在2016年9月份Angular 2正式发布之后,大量的粉丝的开始投入到了Angular 2的怀抱.当然这其中也包括我. ...
 - SNF快速开发平台MVC-各种级联绑定方式,演示样例程序(包含表单和表格控件)
		
做了这么多项目,经常会使用到级联.联动的情况. 如:省.市.县.区.一级分类.二级分类.三级分类.仓库.货位. 方式:有表单需要做级联的,还是表格行上需要做级联操作的. 实现:实现方法也有很多种方式. ...
 
随机推荐
- Xcode7 免证书真机测试
			
Xcode很早就有个免证书测试,今天我自己也测试了一把,还是挺好用的,接下来,我就说一下我的大体过程: 注意:一定要让你的真机设备的系统版本和app的系统版本想对应,如果不对应就会出现一个很常见的问题 ...
 - Is it possible to run native sql with entity framework?
			
For .NET Framework version 4 and above: use ObjectContext.ExecuteStoreCommand() if your query return ...
 - springMVC源码下载地址
			
https://github.com/spring-projects/spring-framework/tags可以选择需要的版本进行下载.
 - hibernate--ID生成策略--XML
			
xml生成id, a) generator b) 常用4个: native, uuid, identity, sequence 1. 新建java项目, 引入hibernate, junit(use ...
 - 安装PIL遇到的问题
			
配置:Win7 64位 不过折腾到最后,没有使用PIL,官方的PIL很久木有更新了,换了Pillow,是PIL的衍生吧,一直有更新,但是两者不可在同一环境共存. 1 Python version 2. ...
 - Application_Start和Application_End事件执行时间
			
Application_start: 第一个访问网站的用户会触发该方法. 通常会在该方法里定义一些系统变量,如聊天室的在线总人数统计,历史访问人数统计的初始化等等均可在这里定义. Applicatio ...
 - HDU 5620 KK's Steel
			
想了一下发现是斐波那契数列.....水题 #include <stdio.h> #include <algorithm> #include <string.h> # ...
 - CodeForces 626D Jerry's Protest
			
计算前两盘A赢,最后一盘B赢的情况下,B获得的球的值总和大于A获得的球总和值的概率. 存储每一对球的差值有几个,然后处理一下前缀和,暴力枚举就好了...... #include<cstdio&g ...
 - HTML学习(八)列表和块
			
无序列表无序列表是一个项目的列表,此列项目使用粗体圆点(典型的小黑圆圈)进行标记.无序列表始于 <ul> 标签.每个列表项始于 <li>.<ul type=“”> ...
 - 入门经典——基础数据结构专题(List)
			
UVA127 链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_pr ...