取模板列值

有的時候想取不是編輯狀態的值,這個時候通常不會使用模板列中放置TextBox通過e.Item.FindControl取值,有的網友問爲什麼取不到?這要看你前臺的列怎麼寫的了,下面分別寫出四種情況和這四種情況下面的取值方式:

<asp:DataGrid id="DataGrid1" runat="server" AutoGenerateColumns="False" AllowPaging="True">
                
<Columns>
                    
<asp:BoundColumn DataField="vName" HeaderText="姓名0"></asp:BoundColumn>
                    
<asp:TemplateColumn HeaderText="姓名1">
                        
<ItemTemplate>
                            姓名
                        
</ItemTemplate>
                    
</asp:TemplateColumn>
                    
<asp:TemplateColumn HeaderText="姓名2">
                        
<ItemTemplate>
                            
<%#DataBinder.Eval(Container.DataItem,"vName")%>
                        
</ItemTemplate>
                    
</asp:TemplateColumn>
                    
<asp:TemplateColumn HeaderText="姓名3">
                        
<ItemTemplate>
                            
<asp:Label ID="name" Runat="server" Text='<%#DataBinder.Eval(Container.DataItem,"vName")%>'>
                            
</asp:Label>
                        
</ItemTemplate>
                    
</asp:TemplateColumn>
                    
<asp:ButtonColumn Text="刪除" ButtonType="PushButton" CommandName="del"></asp:ButtonColumn>
                
</Columns>
            
</asp:DataGrid>

列出了4種大家可能遇到的列:
(1)綁定列
(2)模板列中直接放靜態的字符串
(3)模板列中直接放綁定的字符串
(4)模板列中通過Label放綁定的字符串

下面說明在按下了刪除按鈕以後的四種取值的方式:
if(e.CommandName=="del")
            
{
                Response.Write(DataGrid1.Columns[
0].HeaderText+":"+e.Item.Cells[0].Text+"<br>");
                Response.Write(DataGrid1.Columns[
1].HeaderText+":"+e.Item.Cells[1].Text.Trim()+"<br>");
                Response.Write(DataGrid1.Columns[
2].HeaderText+":"+((DataBoundLiteralControl)e.Item.Cells[2].Controls[0]).Text.Trim()+"<br>");
                Response.Write(DataGrid1.Columns[
3].HeaderText+":"+((Label)e.Item.Cells[3].FindControl("name")).Text+"<br>");                
            }

(1)第一種用綁定列的方式可以直接通過Cells[i].Text取
(2)第二種方式也直接可以取,但是討厭的vs.net總是會在前臺把列中的內容換行,所以這裏還需要對輸出的東西進行去除首尾的空格
(3)第三種方式是網友問的最多的,不能直接通過Cells[i].Text取到值,可以通過上面給出的方法來取,同樣需要去除首尾的空格
(4)第四種方式也是最簡單的方式,當然你可以直接寫e.Item.FindControl("name")
 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章