私の詳細ビューからコントロールをデータバインドでプログラム的に変更できるようにする必要があります。今はこのコードを使用していますが、「インデックスが範囲外です」というエラーが表示されています。詳細ビューからコントロールにプログラムでアクセスするにはどうすればよいですか?
Private Sub dtlApplication_DataBound(ByVal sender As Object, ByVal e As System.EventArgs) Handles dtlApplication.DataBound
Dim resumeLink As HyperLink = dtlApplication.Rows.Item(0).FindControl("lnkResume")
resumeLink.NavigateUrl = "Resumes/"
End Sub
私もこれを試しましたが、オブジェクト参照がオブジェクトのインスタンスに設定されていません。
Private Sub dtlApplication_DataBound(ByVal sender As Object, ByVal e As System.EventArgs) Handles dtlApplication.DataBound
Dim resumeLink As HyperLink = dtlApplication.FindControl("lnkResume")
resumeLink.NavigateUrl = "Resumes/"
End Sub
私はこの問題は、私は私のメインのGridView内の行を選択するまで、それはそれらを得ることはありませんので、ページが最初にロードするときたDetailsViewは、任意のコントロールを持っていないということかもしれないと思います。基本的には、ページが最初に読み込まれたときではなく、グリッドビューで行を選択するときにこのコードを実行しようとしています。それはそれかもしれませんか?もしそうなら、detailsviewデータバインドに含まれていなければ、このコードをどこで実行すべきですか?ここで
はたDetailsViewと、対応するデータソースのマークアップです:
<asp:DetailsView ID="dtlApplication" runat="server" AutoGenerateRows="false"
DataKeyNames="appID" DataSourceID="ds2" CellPadding="0" BorderColor="Transparent"
BorderWidth="0px" GridLines="None" HorizontalAlign="Left" Width="459" CssClass="dtlView">
<Fields>
<asp:TemplateField showheader="false">
<ItemTemplate>
<h3>Resume</h3>
<asp:HyperLink runat="server" ID="lnkResume" Text="View Resume »"></asp:HyperLink>
</ItemTemplate>
</asp:TemplateField>
</Fields>
<PagerSettings Mode="NextPreviousFirstLast" PageButtonCount="5" FirstPageText="← First" LastPageText="Last →"
nextpagetext="Next »" previouspagetext="« Previous" />
<PagerStyle BackColor="#2461BF" ForeColor="White" HorizontalAlign="Center" CssClass="paging" />
</asp:DetailsView>
<asp:SqlDataSource ID="ds2" runat="server" ConnectionString="<%$ ConnectionStrings:cn %>"
SelectCommandType="StoredProcedure" SelectCommand="sp_SelectApplicationDetail"
EnableCaching="true" CacheDuration="600">
<SelectParameters>
<asp:ControlParameter Name="appID" ControlID="gvAdmin" PropertyName="SelectedValue"></asp:ControlParameter>
</SelectParameters>
</asp:SqlDataSource>
を入力してください。 – Alex
マークアップで質問を更新しました –