/***
* name:加载表格或表单数据[通用]
* name:load-table-or-form-data-common.js
*
* author:zengtai
* date:2017-07-19 1501
* notice:原生javascript;兼容所有浏览器版本
*/ /* *
* 加载指定行的表格数据
* @param tableId:表格ID (指定数据类型:string)
* @param lineNumber:所在的表格行号 (指定数据类型:number)
* @return lineData:返回该行数据的数组
* @notice lineData仅包含tbody部分的内容
* @notice lineData将不包含td 的title属性为"useless-data"的文本数据
*/
function getTableLineData(tableId, lineNumber) {
//判断参数
if (arguments.length != 2) {
throw new Error("Arguments' length is not qualified!");
}
if (typeof(tableId) != 'string' || typeof(lineNumber) != 'number') {
throw new Error("Arguments is not qualified!");
} var lineData = []; //行数据 //加载行数据到lineData中
var table = document.getElementById(tableId);
var lines = table.getElementsByTagName('tr');
var line; //选中行
var tds; //选中行的单元格集合 /***
* 去除thead的影响,在getElementsByTagName('tr') 方法中;
* thead将可以作为tr被索引到,但不一定所有的表格中均会使用thead
*/
var line = lines[lineNumber - 1]; //默认第lineNumber行是选中行
if (table.getElementsByTagName('thead')) { //排除 存在 thead标签的对dom操作的影响
line = lines[lineNumber];
} var tds = line.getElementsByTagName('td'); //支持
for (var i = 0; i < tds.length; i++) {
if (tds[i].getAttribute('title') != 'useless-data') {
lineData.push(tds[i].innerText.trim());
}
} return lineData;
} /**
* 加载数据到表单元素中
* @param formId:表单ID;[不一定是Form元素,但一定得是填充数据的表单控件的祖先元素]
* @param datas:数组数据[顺序加载到表单控件中]
* @param datas_config:
* 数组数据的配置项配置:数组中需要加载的元素对应值为true;反之为false;)
* @notice 需要填充数据的项必须设置属性data-fill为'true'
* @notice 需要填充数据的项必须设置类名 'data-fill'
*/
function loadDatasToForms(formId, datas, datas_config) {
//判断参数
if (arguments.length != 3) {
throw new Error("Arguments' length is not qualified!");
}
if (typeof(formId) != 'string' || ((datas instanceof Array) != true)) {
throw new Error("Arguments is not qualified!");
} var form = document.getElementById(formId);
var inputs = form.getElementsByClassName('data-fill'); var j = 0;
for (var i = 0; i < datas.length; i++) {
if (datas_config[i] == true) {
inputs[j].value = datas[i];
// console.log('test:inputs['+ j +']:' + inputs[j].value);
// console.log('test:datas['+ i +']:' + datas[i]);
j++;
}
} }

 

使用示例:

加载数据到模态框:

//step1.函数:

    //加载表格行数据到模态框中
function doLoadLineDatasToModal(tableId, modalId, lineNumber) {
var datas = getTableLineData(tableId, lineNumber); //获取表格行数据,返回该行数据的数组
var data_config = [false, true, true, false]; //配置要装载到模态框中的数组元素(配置方法见该API)
loadDatasToForms(modalId, datas, data_config); //将数组数据装载到模态框中 }

//step2:表格

<table class="table table-border table-striped table-text-veritical-middle" id="independentStatistic_table">
<thead style="background-color: #118ee9;color: white">
<th style="width: 15%;color:white">日期</th>
<th style="width: 15%;color:white">病历份数</th>
<th style="width: 40%;color:white">病历页数</th>
<th style="width: 15%;color:white">操作</th>
</thead>
<tbody>
<tr>
<td>2017-03-07</td>
<td>30</td>
<td>33</td>
<td>
<a href="" class="btn btn_view" data-toggle="modal" data-target="#myModal" onclick="doLoadLineDatasToModal('independentStatistic_table','load-modal-form',1);">修改</a>
</td>
</tr>
<tr>
<td>2017-03-08</td>
<td>125</td>
<td>23</td>
<td>
<a href="" class="btn btn_view" data-toggle="modal" data-target="#myModal" onclick="doLoadLineDatasToModal('independentStatistic_table','load-modal-form',2);">修改</a>
</td>
</tr>
<tr>
<td>2017-03-17</td>
<td>20</td>
<td>87</td>
<td>
<a href="" class="btn btn_view" data-toggle="modal" data-target="#myModal" onclick="doLoadLineDatasToModal('independentStatistic_table','load-modal-form',3);">修改</a>
</td>
</tr>
<tr>
<td>2017-04-09</td>
<td>45</td>
<td>98</td>
<td>
<a href="" class="btn btn_view" data-toggle="modal" data-target="#myModal" onclick="doLoadLineDatasToModal('independentStatistic_table','load-modal-form',4);">修改</a>
</td>
</tr>
<tr>
<td>2017-01-07</td>
<td>19</td>
<td>32</td>
<td>
<a href="" class="btn btn_view" data-toggle="modal" data-target="#myModal" onclick="doLoadLineDatasToModal('independentStatistic_table','load-modal-form',5);">修改</a>
</td>
</tr>
<tr>
<td>2017-03-28</td>
<td>56</td>
<td>45</td>
<td>
<a href="" class="btn btn_view" data-toggle="modal" data-target="#myModal" onclick="doLoadLineDatasToModal('independentStatistic_table','load-modal-form',6);">修改</a>
</td>
</tr>
<tr>
<td>2017-05-02</td>
<td>2</td>
<td>56</td>
<td>
<a href="" class="btn btn_view" data-toggle="modal" data-target="#myModal" onclick="doLoadLineDatasToModal('independentStatistic_table','load-modal-form',7);">修改</a>
</td>
</tr>
<tr>
<td>2017-06-06</td>
<td>63</td>
<td>36</td>
<td>
<a href="" class="btn btn_view" data-toggle="modal" data-target="#myModal" onclick="doLoadLineDatasToModal('independentStatistic_table','load-modal-form',8);">修改</a>
</td>
</tr>
<tr>
<td>2017-04-26</td>
<td>89</td>
<td>60</td>
<td>
<a href="" class="btn btn_view" data-toggle="modal" data-target="#myModal" onclick="doLoadLineDatasToModal('independentStatistic_table','load-modal-form',9);">修改</a>
</td>
</tr>
<tr>
<td>2017-03-06</td>
<td>30</td>
<td>33</td>
<td>
<a href="" class="btn btn_view" data-toggle="modal" data-target="#myModal" onclick="doLoadLineDatasToModal('independentStatistic_table','load-modal-form',10);">修改</a>
</td>
</tr>
</tbody>
</table>

  

//step3:效果图

 

JavaScript之加载表格、表单行数据[插件]的更多相关文章

  1. 【EF学习笔记08】----------加载关联表的数据 显式加载

    显式加载 讲解之前,先来看一下我们的数据库结构:班级表 学生表 加载从表集合类型 //显示加载 Console.WriteLine("=========查询集合===========&quo ...

  2. 【EF学习笔记07】----------加载关联表的数据 贪婪加载

    讲解之前,先来看一下我们的数据库结构:班级表 学生表 贪婪加载 //贪婪加载 using (var db = new Entities()) { var classes = db.Classes.Wh ...

  3. 【EF学习笔记06】----------加载关联表的数据 延迟加载

    讲解之前,先来看一下我们的数据库结构:班级表 学生表 延迟加载 //延迟加载 using (var db = new Entities()) { //查询班级 var classes = (from ...

  4. jqgrid 分页时,清空原表格数据加载返回的新数据

    由于,我们是动态分页,分页后的数据是在触发分页后动态加载而来.如何使jqgrid清空原数据而加载新数据? 1)调用jqgrid的 clearGridData 方法清空表格数据 2)调用jqgrid的  ...

  5. django:bootstrap table加载django返回的数据

    bootstrap table加载表格数据有两类方式: 一种通过data属性的方式配置,一种是javascipt方式配置 这里看js配置方式: 1.当数据源为.json文件时 url参数写上json文 ...

  6. javascript模块加载框架seajs详解

    SeaJS是一个遵循commonJS规范的javascript模块加载框架,可以实现javascript的模块化开发和模块化加载(模块可按需加载或全部加载).SeaJS可以和jQuery完美集成,使用 ...

  7. 前端性能优化:细说JavaScript的加载与执行

    本文主要是从性能优化的角度来探讨JavaScript在加载与执行过程中的优化思路与实践方法,既是细说,文中在涉及原理性的地方,不免会多说几句,还望各位读者保持耐心,仔细理解,请相信,您的耐心付出一定会 ...

  8. KnockoutJS 3.X API 第七章 其他技术(1) 加载和保存JSON数据

    Knockout允许您实现复杂的客户端交互性,但几乎所有Web应用程序还需要与服务器交换数据,或至少将本地存储的数据序列化. 最方便的交换或存储数据的方式是JSON格式 - 大多数Ajax应用程序今天 ...

  9. 转: javascript模块加载框架seajs详解

    javascript模块加载框架seajs详解 SeaJS是一个遵循commonJS规范的javascript模块加载框架,可以实现javascript的模块化开发和模块化加载(模块可按需加载或全部加 ...

随机推荐

  1. jmeter作用域规则

    创建测试计划时,会创建一个有序的一系列将要被执行的请求列表,这些请求通常被组织在有序的控制器下 一些控制器会影响包含在它下面的请求顺序 ,这些特殊的控制器可以参考这里:the component re ...

  2. html5應用緩存

    HTML5使用了應用緩存,就是web應用緩存,使得在離線狀態下可以訪問web'應用. 應用緩存的優點: 離線訪問-可以在無網的狀態下訪問應用 速度-有緩存的應用加載更快 瀏覽器負載-瀏覽器只從服務器加 ...

  3. Uva821-Floyd

    计算所有页面的平均距离. 用floyd求距离,再求平均 #include <algorithm> #include <cstring> #include <ctype.h ...

  4. POJ 1661 (Help Jimmy )

    Help Jimmy Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 13669   Accepted: 4541 Descr ...

  5. luogu1712 区间 (尺取法+线段树)

    先把区间按照长度从小到大排序,然后用尺取法来做 大概就是先一点一点把区间算上 直到某个点被覆盖了m次,然后一点一点把最前面的区间扔掉,直到没有点被覆盖m次,这样反复做(相当于是它选择的区间左右端点在那 ...

  6. bzoj1002/luogu2144 轮状病毒 (dp)

    给周围的点编号1到n 我们设f[i]为(1到i和中间点)连成一个联通块的情况数,那么有$f[i]=\sum{f[i-j]*j}$,就是从i-j+1到i里选一个连到中心,然后再把i-j+1到i连成链 但 ...

  7. Win10删除anaconda重装

    1.找到anaconda安装的文件夹,找到Uninstall-Anaconda.exe,左键双击运行: 2.然后就按照提示开始卸载,会看到如下: 就会卸载完了,然后你就会发现anaconda所在的文件 ...

  8. A1074. Reversing Linked List

    Given a constant K and a singly linked list L, you are supposed to reverse the links of every K elem ...

  9. 如何在通用权限管理系统中集成log4net日志功能

    开发人员都知道,在系统运行中要记录各种日志,自己写一个日志功能,无论是在效率还是功能扩展上来说都不是很好,目前大多用的是第三方的日志系统,其中一个非常有名,用的最多的就是log4net.下面是关于这个 ...

  10. java中的内存空间 堆和栈

        认识堆与栈 栈与堆都是Java用来在Ram中存放数据的地方.与C++不同,Java自动管理栈和堆,程序员不能直接地设置栈或堆.Java的堆是一个运行时数据区,类的对象从中分配空间.这些对象通过 ...