我目前有一个datareader作为我的数据源,它绑定到转发器。如下所示:
Try
myConnection.Open()
sqlCommand = New SqlCommand(sqlText, myConnection)
dr = sqlCommand.ExecuteReader(CommandBehavior.CloseConnection)
cropPlanRepeater.DataSource = dr
cropPlanRepeater.DataBind()
Catch ex As Exception
End Try
这将启动数据绑定事件,如下所示:
Public Sub CropPlanRepeater_ItemDataBound(ByVal source As Object, ByVal e As System.Web.UI.WebControls.RepeaterItemEventArgs) Handles cropPlanRepeater.ItemDataBound
Dim rptI As RepeaterItem = e.Item
Dim AmttoSell = TryCast(rptI.FindControl("amtToSell"), Label)
AmttoSell.Text = AmttoSell
End Sub
由于某种原因,这个findcontrol方法,一直返回“null”或“nothing”我试图看看我的控件和诸如此类的东西是否存在缺陷,但我找不到任何东西。
这是用于查看其工作原理的HTML:
<asp:Repeater ID="cropPlanRepeater" runat="server" Visible="false">
<HeaderTemplate>
<tr align="center" class="top-rpt-head">
<th scope="col">
Crop
</th>
<th scope="col">
Production
</th>
<th scope="col">
Amount to Sell
</th>
<th scope="col">
Breakeven
</th>
<th scope="col">
Target Price
</th>
<th scope="col">
Target Revenue
</th>
<th scope="col">
Feed Value
</th>
<th scope="col">
Other Income
</th>
<th scope="col">
Expenses
</th>
<th scope="col">
Profit
</th>
</tr>
</HeaderTemplate>
<ItemTemplate>
<tr align="center">
<td>
<!--- this needs to be fixed- incorrect methodology(should be done in the codebehind)----->
<%# (DataBinder.Eval(Container.DataItem, "Crop_Name"))%>
</td>
<td>
<!--- this needs to be fixed- incorrect methodology(should be done in the codebehind)----->
<%# (DataBinder.Eval(Container.DataItem, "Acres_D") * DataBinder.Eval(Container.DataItem, "Yield_D") + DataBinder.Eval(Container.DataItem, "Acres_I") * DataBinder.Eval(Container.DataItem, "Yield_I"))%>
</td>
<td>
</td>
</tr>
<asp:label runat="server" ID="AmtToSell"></asp:Label>
<asp:Literal runat="server" ID="Yield_I" Text='<%#Eval("Yield_I") %>' Visible="false" />
<asp:Literal runat="server" ID="Yield_D" Text='<%#Eval("Yield_D") %>' Visible="false" />
<asp:Literal runat="server" ID="Acres_I" Text='<%#Eval("Acres_I") %>' Visible="false" />
<asp:Literal runat="server" ID="Acres_D" Text='<%#Eval("Acres_D") %>' Visible="false" />
<asp:Literal runat="server" ID="Storage" Text='<%#Eval("Storage") %>' Visible="false" />
<asp:Literal runat="server" ID="Fed" Text='<%#Eval("Fed") %>' Visible="false" />
<asp:Literal runat="server" ID="Bartered" Text='<%#Eval("Bartered") %>' Visible="false" />
<asp:Literal runat="server" ID="Profit_I" Text='<%#Eval("ProfAcre_I") %>' Visible="false" />
<asp:literal runat="server" ID="Profit_D" Text='<%#Eval("ProfAcre_D") %>' Visible="false" />
</ItemTemplate>
</asp:Repeater>
我已经尝试将标签放在桌子的内部和外部,但无济于事。我不确定我的HTML或代码隐藏是否存在问题。我需要在代码隐藏中使用计算来操作标签“amttosell”。 (我会做一些像amttosell.text = 从数据库中获取的数据/在上面的隐藏标签上发布的一些计算
任何帮助都会非常感激。
答案 0 :(得分:0)
CropPlanRepeater_ItemDataBound方法处理页眉,页脚和项目。对于您拥有的代码,您需要将其包装在if
块中,检查项类型是Item还是AlternateItem。
Public Sub CropPlanRepeater_ItemDataBound(ByVal source As Object, ByVal e As System.Web.UI.WebControls.RepeaterItemEventArgs) Handles cropPlanRepeater.ItemDataBound
Dim rptI As RepeaterItem = e.Item
if rptI.ItemType = ListItemType.Item OR rptI.ItemType = ListItemType.AlternatingItem then
Dim AmttoSell = TryCast(rptI.FindControl("amtToSell"), Label)
AmttoSell.Text = AmttoSell
end if
End Sub
请参阅http://msdn.microsoft.com/en-us/library/system.web.ui.webcontrols.repeater.itemdatabound.aspx#Y200