Verwenden eines ConfirmButton-Steuerelements in einem Wiederholungssteuerelement (C#)
von Christian Wenz
Der ConfirmButton-Extender im AJAX Control Toolkit erstellt ein Ja/Nein-Popup, wenn der Benutzer auf eine Schaltfläche klickt (einschließlich LinkButton-Steuerelement). Nur wenn auf Ja geklickt wird, wird die Aktion der Schaltfläche ausgeführt, andernfalls abgebrochen. Dies ist auch in einem Repeater möglich.
Überblick
Der ConfirmButton-Extender im AJAX Control Toolkit erstellt ein Ja/Nein-Popup, wenn der Benutzer auf eine Schaltfläche klickt (einschließlich LinkButton-Steuerelement). Nur wenn auf Ja geklickt wird, wird die Aktion der Schaltfläche ausgeführt, andernfalls abgebrochen. Dies ist auch in einem Repeater möglich.
Schritte
Zunächst ist eine Datenquelle erforderlich. In diesem Beispiel werden die AdventureWorks-Datenbank und die Microsoft-SQL Server 2005 Express Edition verwendet. Die Datenbank ist optionaler Bestandteil einer Visual Studio-Installation (einschließlich Express Edition) und steht auch als separater Download unter https://go.microsoft.com/fwlink/?LinkId=64064zur Verfügung. Die AdventureWorks-Datenbank ist Teil der SQL Server 2005 Samples and Sample Databases (Download unter https://www.microsoft.com/download/details.aspx?id=10679). Die einfachste Möglichkeit zum Einrichten der Datenbank besteht darin, die Microsoft SQL Server Management Studio (/sql/ssms/download-sql-server-management-studio-ssms) zu verwenden und die AdventureWorks.mdf
Datenbankdatei anzufügen.
Für dieses Beispiel wird davon ausgegangen, dass die instance der SQL Server 2005 Express Edition aufgerufen SQLEXPRESS
wird und sich auf demselben Computer wie der Webserver befindet. Dies ist auch das Standardsetup. Wenn ihr Setup unterschiedlich ist, müssen Sie die Verbindungsinformationen für die Datenbank anpassen.
Um die Funktionalität von ASP.NET AJAX und dem Control Toolkit zu aktivieren, muss das ScriptManager
Steuerelement an einer beliebigen Stelle auf der Seite (aber innerhalb des <form>
Elements) platziert werden:
<asp:ScriptManager ID="asm" runat="server" />
Anschließend ist eine Datenquelle erforderlich. Der Einfachheit halber werden nur die ersten fünf Einträge in der Vendors-Tabelle von AdventureWorks abgerufen. Beachten Sie, dass beim Erstellen der Datenquelle mit dem Visual Studio-Assistenten dem Tabellennamen (Vendors
) derzeit nicht ordnungsgemäß vorangestellt Purchasing
wird. Das folgende Markup ist das richtige:
<asp:SqlDataSource ID="sds1" runat="server" ConnectionString="
Data Source=(local)\SQLEXPRESS;Initial Catalog=AdventureWorks;Integrated Security=True"
ProviderName="System.Data.SqlClient" SelectCommand="SELECT TOP 5
[VendorID], [Name] FROM [Purchasing].[Vendor]" />
Diese Datenquelle kann dann innerhalb eines Repeaters verwendet werden. Wie üblich ruft die DataBinder.Eval()
-Methode Daten aus der Datenquelle ab. Das ConfirmButtonExtender
Steuerelement muss dann innerhalb des <ItemTemplate>
Abschnitts des Repeaters platziert werden, damit es für jeden Eintrag in der Datenquelle angezeigt wird.
<div>
<ul>
<asp:Repeater ID="rep1" DataSourceID="sds1" runat="server">
<ItemTemplate>
<li>
<%#DataBinder.Eval(Container.DataItem, "Name")%>
<asp:LinkButton ID="btn1" Text="Remove Item" runat="server" />
<ajaxToolkit:ConfirmButtonExtender ID="cfe1" runat="server" TargetControlID="btn1" ConfirmText="Are you sure?!" />
</li>
</ItemTemplate>
</asp:Repeater>
</ul>
</div>
Die Schaltfläche Bestätigen wird neben jedem Eintrag aus der Datenquelle angezeigt (Klicken Sie hier, um das Bild in voller Größe anzuzeigen)