`
helloJ
  • 浏览: 166556 次
  • 性别: Icon_minigender_1
  • 来自: 厦门
社区版块
存档分类
最新评论

js动态计算table某列值的总和

    博客分类:
  • js
阅读更多
/**
 * 
 * @tableId 表格id
 * @numId 显示张数id
 * @index 列数
 * @first 首次标识
 * @obj checkbox对象
 */
function countNum(tableId, numId, index, first,obj) {
	var sumStr = document.getElementById(numId);
	//当前行进行加减
	if (null != obj) {
		var num = new Number(obj.parentElement.parentElement.cells[index].innerText);
		if (obj.checked) {
			sumStr.value = new Number(sumStr.value) + num;
		}
		else {
			sumStr.value = new Number(sumStr.value) - num;
		}
	}
	//遍历所有进行加减
	else {
		var table = document.getElementById(tableId);
		var sum = 0;
		var rows = table.rows;
		for (i = 1; i < rows.length; i++) {
                                                //判断是否有复选框
			var checkObj = rows[i].cells[0].all[0];
			var flag = false;
			if (null != checkObj 
				&& typeof checkObj.type != 'undefined'
				&&  checkObj.type == 'checkbox') {
				flag = checkObj.checked;
			}
                                                //首次默认计算全部或增加选中的值
			if (first || flag) {
				var num = new Number(rows[i].cells[index].innerText);
				sum = sum + num;
			}
		}
		sumStr.value = sum;
	}
}

 1. jsp,带复选框

<xmdc:form style="position:relative;top:10px;" id="AEDT_account">
<xmdc:panelGrid columns="10" width="98%" styleClass="content_table"
				align="center" columnwidths="4%,6%,4%,8.5%,4%,6%,5%,5.5%,2.5%,4.5%"
				columnaligns="right,left,right,left,right,left,right,left,right,left"
				columnClasses="content_index,content_body,content_index,content_body,
					content_index,content_body,content_index,content_body,content_index,content_body">

				<xmdc:outputText value="移交人员"></xmdc:outputText>
				<xmdc:panelGroup>
					<xmdc:inputText style="width:80px;validator:checkNotNull(移交人员);"
						value="#{AddExistDataTransfer.transferBFO.transferOperatorName}"
						onchange="reExport();"></xmdc:inputText>
					<xmdc:outputText value="*" style="color:red;"></xmdc:outputText>
				</xmdc:panelGroup>
				<xmdc:outputText value="移交日期"></xmdc:outputText>
				<xmdc:panelGroup>
					<xmdc:ccbcalendar
						value="#{AddExistDataTransfer.transferBFO.transferDate}"
						id="transferDate"></xmdc:ccbcalendar>
					<xmdc:outputText value="*" style="color:red;"></xmdc:outputText>
				</xmdc:panelGroup>
				<xmdc:outputText value="签收人员"></xmdc:outputText>
				<xmdc:panelGroup>
					<xmdc:inputText style="width:80px;validator:checkNotNull(签收人员)"
						value="#{AddExistDataTransfer.transferBFO.receiveOperatorName}"
						onchange="reExport();"></xmdc:inputText>
					<xmdc:outputText value="*" style="color:red;"></xmdc:outputText>
				</xmdc:panelGroup>
				<xmdc:outputText value="签收人员编号"></xmdc:outputText>
				<xmdc:panelGroup>
					<xmdc:inputText style="width:100px;validator:checkNotNull(签收人员编号)"
						value="#{AddExistDataTransfer.transferBFO.receiveOperatorNo}"
						onchange="reExport();"></xmdc:inputText>
					<xmdc:outputText value="*" style="color:red;"></xmdc:outputText>
				</xmdc:panelGroup>
				<xmdc:outputText value="张数"></xmdc:outputText>
				<xmdc:inputText id="number" readonly="true" style="width:70px;"></xmdc:inputText>
			</xmdc:panelGrid>
			<xmdc:panelGrid width="100%">
				<xmdc:div styleClass="auto" style="height:375px;width:100%">
					<xmdc:dataTable var="row" cellpadding="2" styleClass="sortable"
						value="#{AddExistDataTransfer.unTransferExistList}"
						style="width:100%" id="countNumT">
						<xmdc:column width="4%">
							<xmdc:facet name="header">
								<xmdc:selectBooleanCheckbox
									onclick="selectAll(this);
											countNum('AEDT_account:countNumT', 'AEDT_account:number',4,false);">
								</xmdc:selectBooleanCheckbox>
							</xmdc:facet>
							<xmdc:selectBooleanCheckbox value="#{row.select}"
								onclick="reExport();
										countNum('AEDT_account:countNumT', 'AEDT_account:number',4,false,this);">
							</xmdc:selectBooleanCheckbox>
						</xmdc:column>
						<xmdc:column width="160px">
							<xmdc:facet name="header">
								<xmdc:outputText value="账号"></xmdc:outputText>
							</xmdc:facet>
							<xmdc:outputText value="#{row.accountNo}"></xmdc:outputText>
						</xmdc:column>
						<xmdc:column>
							<xmdc:facet name="header">
								<xmdc:outputText value="户名"></xmdc:outputText>
							</xmdc:facet>
							<xmdc:outputText value="#{row.accountName}"></xmdc:outputText>
						</xmdc:column>
						<xmdc:column>
							<xmdc:facet name="header">
								<xmdc:outputText value="操作类型"></xmdc:outputText>
							</xmdc:facet>
							<xmdc:outputText value="#{row.operateType}"></xmdc:outputText>
						</xmdc:column>
						<xmdc:column>
							<xmdc:facet name="header">
								<xmdc:outputText value="张数"></xmdc:outputText>
							</xmdc:facet>
							<xmdc:outputText value="#{row.count}"></xmdc:outputText>
						</xmdc:column>
					</xmdc:dataTable>
				</xmdc:div>
			</xmdc:panelGrid>

			<xmdc:verbatim>
				<script type="text/javascript">
					countNum("AEDT_account:countNumT", "AEDT_account:number",4,true);
				</script>
			</xmdc:verbatim>
</xmdc:form>

  2. jsp,不带复选框

<xmdc:form style="position:relative;top:10px;" id="DTRD_account">
<xmdc:panelGrid columns="10" width="98%" styleClass="content_table"
				align="center" columnwidths="8%,13%,8%,13%,8%,13%,8%,13%,5%,11%"
				columnaligns="right,left,right,left,right,left,right,left,right,left"
				columnClasses="content_index,content_body,content_index,content_body,
					content_index,content_body,content_index,content_body,content_index,content_body">
				<xmdc:outputText value="移交人"></xmdc:outputText>
				<xmdc:outputText
					value="#{DataTransferReceiveDetail.bfo.transferOperatorName}"></xmdc:outputText>
				<xmdc:outputText value="移交日期"></xmdc:outputText>
				<xmdc:outputText
					value="#{DataTransferReceiveDetail.bfo.transferDate.val}"></xmdc:outputText>
				<xmdc:outputText value="签收人员"></xmdc:outputText>
				<xmdc:outputText
					value="#{DataTransferReceiveDetail.bfo.receiveOperatorName}"></xmdc:outputText>
				<xmdc:outputText value="签收日期"></xmdc:outputText>
				<xmdc:outputText
					value="#{DataTransferReceiveDetail.bfo.receiveDate.val}"></xmdc:outputText>
				<xmdc:outputText value="张数"></xmdc:outputText>
				<xmdc:inputText id="number" readonly="true"></xmdc:inputText>
			</xmdc:panelGrid>
			<xmdc:panelGrid width="100%">
				<xmdc:div styleClass="auto" style="height:420px;width:100%">
					<xmdc:dataTable var="row" cellpadding="0" styleClass="sortable"
						value="#{DataTransferReceiveDetail.detailList}" style="width:100%"
						id="countNumT">
						<xmdc:column width="165px">
							<xmdc:facet name="header">
								<xmdc:outputText value="账号"></xmdc:outputText>
							</xmdc:facet>
							<xmdc:outputText value="#{row.accountNo}"></xmdc:outputText>
						</xmdc:column>
						<xmdc:column>
							<xmdc:facet name="header">
								<xmdc:outputText value="户名"></xmdc:outputText>
							</xmdc:facet>
							<xmdc:outputText value="#{row.accountName}"></xmdc:outputText>
						</xmdc:column>
						<xmdc:column>
							<xmdc:facet name="header">
								<xmdc:outputText value="操作类型"></xmdc:outputText>
							</xmdc:facet>
							<xmdc:outputText value="#{row.operateType}"></xmdc:outputText>
						</xmdc:column>
						<xmdc:column>
							<xmdc:facet name="header">
								<xmdc:outputText value="张数"></xmdc:outputText>
							</xmdc:facet>
							<xmdc:outputText value="#{row.count}"></xmdc:outputText>
						</xmdc:column>
						<xmdc:column>
							<xmdc:facet name="header">
								<xmdc:outputText value="是否电子审批"></xmdc:outputText>
							</xmdc:facet>
							<xmdc:outputText value="#{row.echief}"></xmdc:outputText>
						</xmdc:column>
					</xmdc:dataTable>
				</xmdc:div>
			</xmdc:panelGrid>

			<xmdc:verbatim>
				<script type="text/javascript">
					countNum("DTRD_account:countNumT", "DTRD_account:number",3,true);
				</script>
			</xmdc:verbatim>
</xmdc:form>

 

分享到:
评论
2 楼 xuehua1987 2012-03-16  
用js怎么能取到<xmdc:outputText value="#{row.operateType}"></xmdc:outputText中的value值?
1 楼 mleave 2009-01-08  
晕倒 随便搜居然搜到这里来了,jh 知道我是谁吧 哈哈

相关推荐

    js获取table行 列 的值

    下面我们将详细介绍如何通过 JavaScript 来获取 HTML 表格(`&lt;table&gt;`)中的行(`&lt;tr&gt;`)和列(`&lt;td&gt;`)的值。 #### 核心知识点解析 ### 一、HTML 结构解析 首先,让我们来分析一下给定的 HTML 代码结构: ```...

    解决vue 表格table列求和的问题

    在使用Vue.js框架开发时,表格的数据计算和展示是常见的需求之一,尤其是在处理业务报表时,对某列数据进行求和是非常重要的功能。本文将介绍如何在Vue项目中实现表格列的求和功能,虽然原项目中使用了element-ui库...

    用Jquery选择器计算table中的某一列某一行的合计

    &lt;title&gt;jQuery计算table行合计 &lt;script src="http://runjs.cn/js/sandbox/jquery/jquery-1.8.3.min.js"&gt; $(document).ready(function() { var totalRow = 0; $('#mytable tr').each(function() { $(this)....

    Bootstrap-table分页+汇总统计

    例如,如果要计算某一列的总和,可以这样写: ```javascript function summaryFunction(data) { var sum = 0; for (var i = 0; i ; i++) { sum += parseFloat(data[i].column_name); } return "总计: " + sum;...

    bootstrap table sum总数量统计实现方法

    这样,如果后端已经计算了总和,我们可以直接使用这个值,否则使用 `footerFormatter` 在前端计算。 示例 JSON 结构: ```json { "total": 2, "rows": [ {"id": 1, "categoryid": 11, "money": 100, "creattime...

    计算机软件-商业源码-243 利用Table的过滤机制实现动态查询和统计.zip

    在本例中,可能涉及到计算表中某一列的总和、平均值等统计指标,或者找出最频繁出现的项。这通常需要在查询过程中使用聚合函数,如SUM、AVG、COUNT、MAX和MIN,它们可以帮助我们了解数据的整体特征。 为了实现这些...

    js 动态电子表

    对于计算,JavaScript提供了一系列数学函数,可以用于计算单元格的值,如总和、平均值等。 为了提升用户体验,还可以添加一些视觉效果,如高亮选择的单元格、过渡动画等。CSS3和JavaScript库如jQuery UI或Bootstrap...

    flexible_table.zip

    在本项目"flexible_table.zip"中,我们探讨了一个基于Vue.js和jQuery(jq)实现的灵活表格,这个表格特别适用于模拟购物车功能,允许用户选择商品并计算总价。下面将详细阐述其中涉及的关键技术点。 1. **Vue.js**...

    element-table.zip

    可以将单选按钮嵌入到表格的某一列中,通过绑定 `v-model` 来控制选中的值,然后根据这个值进行评分计算。 4. **表格内换行**: 在表格单元格中插入换行符(` `)可以实现文本的换行展示。这在处理长文本或者...

    javascript表格常用操作 表头排序 表头固定 列隐藏 行隐藏

    在JavaScript和jQuery的世界里,表格(Table)是数据展示的重要工具。本教程将重点讲解如何实现"javascript表格常用操作",包括"表头排序"、"表头固定"、"列隐藏"、"行隐藏"以及"悬浮变色"等功能。这些功能可以极大...

    Bootstrap-table使用footerFormatter做统计列功能

    在实际的开发中,经常需要在表格底部添加统计行,例如计算某列的总和、平均值等。`footerFormatter` 就是 Bootstrap-table 提供的一个功能,用于自定义表格底部(footer)的显示内容,非常适合用来实现统计功能。 `...

    webix数据表格锁列-翻页-统计示列

    **数据统计** 可能涉及计算某一列的总和、平均值等。Webix提供了`dataProcessor`组件,可以配合服务器端进行数据处理。你也可以自定义函数来实现局部统计。例如,可以监听`onAfterLoad`事件,遍历数据集并计算总和:...

    Javascript表格數字加總範例

    JavaScript表格数字加总是一个常见的前端开发任务,尤其在处理数据展示和计算时。在这个范例中,我们将讨论如何使用JavaScript来实现对HTML表格中的数字进行加总,并解决在Internet Explorer浏览器中可能出现的问题...

    MySQL DQL - 聚合函数.md

    这条SQL语句将返回`sales`表中的行数、`amount`列的总和、平均值、最大值和最小值。 #### 总结 通过上述介绍和示例,我们可以看出聚合函数在MySQL数据库中是非常有用的工具,可以方便地帮助我们进行数据汇总与分析...

    几个经典JavaScript控件下载

    这里的grid表格控件可能不仅支持基本的数据列展示,还包含了合计行功能,这意味着它能够自动计算一列或多列的总和或其他统计值,如平均值或最大值,这对于数据分析和报告制作十分有用。 3. **Select的JavaScript...

    javascript表格操作

    `getSum()`函数可以用于计算指定列的总和,并将结果显示在文本框中。这一过程涉及到遍历所有相关的单元格,提取数值信息,并执行数学运算。 ### 综合运用 将以上技术结合使用,可以构建出功能强大的表格操作界面。...

    MySQL DQL - 分组查询.md

    **解析**:这里我们使用`SUM(column_name)`函数来计算每个分组中`column_name`列的值的总和。 ##### 示例3:按列进行分组,并计算每个分组中的平均值 ```sql SELECT column_name, AVG(column_name) FROM table_...

    layui table 列宽百分比显示的实现方法

    首先,实现Layui table列宽百分比显示的思路是通过计算表格的总宽度,然后根据每个列的百分比宽计算出每个列的实际像素宽度。Layui table允许我们通过cols配置项自定义列的配置,包括设置列宽,这为实现百分比宽度...

    HTML制作电子发票收据凭证界面,并可填写数字中文数字,自动计算合计等功能.zip

    例如,可以通过遍历所有相关`&lt;td&gt;`元素,提取其值,转换为数字,然后累加得到总和。 此外,"效果图.png"很可能是展示完成后的发票收据界面,用户可以通过这个图片预览最终效果,确保设计符合预期。而"2lj改进版...

Global site tag (gtag.js) - Google Analytics