计算gridview字段总数并使用javascript在页脚文本框中显示

时间:2011-05-23 16:55:07

标签: javascript jquery

我很想找出gridview单元格的总数并显示这些值 页脚文本框。每次我得到例外:请帮助我,我做错了什么:

这是例外: Microsoft JScript运行时错误:预期的对象 * 以下是我的gridview代码: *

 <div>
 <asp:gridview ID="Gridview1" runat="server" ShowFooter="true" 
        onrowcommand="Gridview1_RowCommand"  AutoGenerateColumns="false" 
        CellSpacing="0" CellPadding="0" Font-Bold="false" 
        onrowdeleting="Gridview1_RowDeleting">
    <Columns>
  <asp:BoundField DataField="RowNumber" HeaderText="Row Number"/>
  <asp:TemplateField HeaderText="Select" ControlStyle-Width="50px" HeaderStyle-Font-Bold="false" ControlStyle-Font-Bold="false">
 <ItemTemplate>
     <asp:CheckBox ID="chkSelect" runat="server" Width="80px"/>
 </ItemTemplate>     
 </asp:TemplateField>
    <asp:TemplateField HeaderText="Header 1" HeaderStyle-Font-Bold="false"  ControlStyle-Font-Bold="false">
        <ItemTemplate>
            <asp:TextBox ID="TextBox1" runat="server" Width="70px"></asp:TextBox>
        </ItemTemplate>            
        <FooterTemplate>
            <asp:Label ID="lblTotal" runat="server" Text="Total" Font-Bold="true">       </asp:Label>
        </FooterTemplate>            
    </asp:TemplateField>
    <asp:TemplateField HeaderText="Header 2"  HeaderStyle-Font-Bold="false" ControlStyle-Font-Bold="false">
        <ItemTemplate>
            <asp:TextBox ID="TextBox2" Width="70px" runat="server" onkeyup="Calculate('Gridview1')"></asp:TextBox>
        </ItemTemplate>            
        <FooterTemplate>
            <asp:TextBox ID="total" runat="server" Width="70px"></asp:TextBox>
        </FooterTemplate>            
    </asp:TemplateField>
    <asp:TemplateField HeaderText="Header 3" HeaderStyle-Font-Bold="false" ControlStyle-Font-Bold="false">
        <ItemTemplate>
             <asp:TextBox ID="TextBox3" Width="70px" runat="server" ></asp:TextBox>
        </ItemTemplate>
        <FooterStyle HorizontalAlign="Right" />
        <FooterTemplate>
         <asp:Button ID="ButtonAdd" runat="server" Text="Add New Row" CommandName="AddNewRow" />
        </FooterTemplate>
    </asp:TemplateField>
    </Columns>
  </asp:gridview>   
  </div>

这是我的JavaScript代码:

   <script type="text/javascript" src="http://ajax.aspnetcdn.com/ajax/jquery/jquery-1.5.js"></script>  
<script type="text/javascript" src="http://ajax.aspnetcdn.com/ajax/jquery.ui/1.8.10/jquery-ui.js"></script> 
<script type="text/javascript">  
function Calculate(GridView)
{
   var total = 0;   
   var gridview = document.getElementById('<%=Gridview1.ClientID %>').getElementsByTagName("input");        
   for ( i = 0; i < gridview.rows.length; i ++)
   {
       var node = gridview.rows[i].cells[3].childNodes[3]; //textbox  

       if (node != undefined && node.type == "text") //check only textbox, ignore empty one
            if (!isNaN(node.value) && node.value != "") //check for valid number
               total += parseInt(node.value); 
   }       
  // document.getElementById("total").innerHTML = total.toString(); //display
   var gridview1 = document.getElementById('<%=grdview1.ClientID %>');
   gridview1.rows[gridview.rows.length -1].cells[0].innerHTML=total;

}

我尝试了很多方法,但每次都得到同样的例外: Microsoft JScript运行时错误:预期的对象

我的JavaScript代码似乎有问题..请某人帮助我。

1 个答案:

答案 0 :(得分:1)

你的函数不需要接受一个对象,因为你没有在你的javascript中使用它,你通过GridView的方式我认为无论如何都不会工作。

我认为如果你利用一些jQuery选择器来找到你需要的DOM中的元素,你的javascript会更简洁,更容易理解。您可以为要合计的文本框使用特殊类,例如:

....
<asp:TemplateField HeaderText="Header 1" HeaderStyle-Font-Bold="false"  ControlStyle-Font-Bold="false">
    <ItemTemplate>
        <asp:TextBox ID="TextBox1" Class="TotalBox" runat="server" Width="70px"></asp:TextBox>
    </ItemTemplate>            
    <FooterTemplate>
        <asp:Label ID="lblTotal" Class="TotalLabel" runat="server" Text="Total" Font-Bold="true">       </asp:Label>
    </FooterTemplate>            
</asp:TemplateField>
....

Javacript

<script type="text/javascript">
function Calcutate()
{
     var total = 0;
     $('.TotalBox').each(function() {
         total = parseInt(this.val()) + total;
     });

     $('.TotalLabel').html(total);
}
</script>