用js实现gridview某列自动求和,或某行自动求和

<script type="text/javascript">

      //实现某列自动求和:

      function colSum(colIndex)//colIndex指定列的索引

     {

           //根据gridview的客户端ID(GridView1.ClientID)获取编译后此gridview的行数

           var trs=document.getElementById("<%=GridView1.ClientID%>").getElementByTagName("TR")

           var sum=0;

           //i表示行号,行号从1开始(注意:如果没有表头可以从1开始,有表头就要把表头去掉)

           for(var i=4;i<trs.length;i++)

          {

                //把每行中指定列的值相加

                sum+=trs[i].document.getElementByTagName("td")[colIndex].childNodes[0].value*1;

          }

          //把结果赋给指定的单元格

          trs[3]].document.getElementByTagName("td")[colIndex].childNodes[0].value=sum;

     }

     //实现某行中的几个单元格自动求和:

      function rowSum(rowIndex)//rowIndex指定行的索引
       {
         
          var trs=document.getElementById("<%=GridView1.ClientID%>").getElementsByTagName("TR")
          //获取指定行中某单元格的值
          var Value4=(trs[rowIndex].getElementsByTagName("td")[4].childNodes[0].value)*1;
          var Value5=(trs[rowIndex].getElementsByTagName("td")[5].childNodes[0].value)*1;
          var Value6=(trs[rowIndex].getElementsByTagName("td")[6].childNodes[0].value)*1;
          var Value7=(trs[rowIndex].getElementsByTagName("td")[7].childNodes[0].value)*1;
          var Value8=(trs[rowIndex].getElementsByTagName("td")[8].childNodes[0].value)*1;
        
          trs[rowIndex].getElementsByTagName("td")[3].childNodes[0].value=Value4+Value5+Value6+Value7+Value8;
      }

</script>

 

 

<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" SkinID="GridViewStyle" >                        <Columns>
                       <asp:TemplateField>
                                 <ItemTemplate>
                                     <asp:TextBox ID="txtCeShi" runat="server" Text='<%# Eval("CeShi") %>' Width ="150px"  οnblur="colSum(1);rowSum(this.parentElement.parentElement.rowIndex)"></asp:TextBox>

                                 </ItemTemplate>
                            </asp:TemplateField>

 <Columns>

</asp:GridView>

 onblur是当鼠标离开此文本框时触发

谁还有更好的方法吗?总觉得行求和的时候,一个单元格一个单元格的取值然后再相加有点复杂......

转载于:https://www.cnblogs.com/lanbingyu0801/archive/2012/06/09/2543350.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值