Exemplarische Vorgehensweise: Anzeigen formatierter Daten in Webseiten mit dem FormView-Webserversteuerelement
Aktualisiert: November 2007
ASP.NET enthält verschiedene Steuerelemente, mit denen Sie Datensätze anzeigen und bearbeiten können. In dieser exemplarischen Vorgehensweise arbeiten Sie mit dem FormView-Steuerelement, das jeweils mit einem einzelnen Datensatz arbeitet. Das primäre Feature des FormView-Steuerelements ist, dass es Ihnen ermöglicht, das Layout eines Datensatzes über die Definition von Vorlagen selbst zu erstellen. Wenn Sie mit Vorlagen arbeiten, können Sie das Layout und die Darstellung von Daten in dem Steuerelement vollständig steuern. Das FormView-Steuerelement unterstützt auch Aktualisierungen, z. B. das Bearbeiten, Einfügen und Löschen von Datensätzen. Wenn die Datenquelle dem FormView-Steuerelement mehr als einen Datensatz bereitstellt, können Sie mit diesem Steuerelement einen Bildlauf durch die einzelnen Datensätze durchführen.
Hinweis: |
---|
Sie können auch einzelne Datensätze mit dem DetailsView-Steuerelement bearbeiten. Dieses stellt vordefinierte Layouts für die Daten bereit. Weitere Informationen finden Sie unter Übersicht über das DetailsView-Webserversteuerelement. |
Zu den Aufgaben in dieser exemplarischen Vorgehensweise gehören:
Erstellen einer Seite zum Anzeigen von Master-Detail-Informationen.
Verwenden eines FormView-Steuerelements zum Erstellen eines Freiformlayouts für einen Datensatz.
Konfigurieren des FormView-Steuerelements, um eine Bearbeitung zu ermöglichen.
Vorbereitungsmaßnahmen
Für die Durchführung dieser exemplarischen Vorgehensweise benötigen Sie Folgendes:
Microsoft Visual Web Developer.
Zugriff auf die Northwind-Datenbank in SQL Server. Informationen über das Herunterladen und Installieren der SQL Server-Beispieldatenbank Northwind finden Sie auf der Microsoft SQL Server-Website unter Installing Sample Databases.
Hinweis: Wenden Sie sich an den Serveradministrator, wenn Sie Informationen zur Anmeldung an dem Computer benötigen, auf dem SQL Server ausgeführt wird.
Microsoft Data Access Components (MDAC), Version 2.7 oder höher.
Wenn Sie Microsoft Windows XP oder Windows Server 2003 verwenden, verfügen Sie bereits über MDAC 2.7. Wenn Sie jedoch Microsoft Windows 2000 verwenden, müssen Sie möglicherweise die bereits auf dem Computer installierte Version von MDAC aktualisieren. Weitere Informationen finden Sie unter "Microsoft Data Access Components (MDAC) Installation" in der MSDN Library.
Erstellen der Website
Erstellen Sie eine neue Website und eine neue Webseite, indem Sie folgende Schritte ausführen.
So erstellen Sie eine Dateisystem-Website
Öffnen Sie Visual Web Developer.
Klicken Sie im Menü Datei auf Neu, und klicken Sie anschließend auf Website. Wenn Sie Visual Web Developer Express verwenden, klicken Sie im Menü Datei auf Neue Website.
Das Dialogfeld Neue Website wird angezeigt.
Klicken Sie unter Von Visual Studio installierte Vorlagen auf ASP.NET-Website.
Geben Sie im Feld Speicherort den Namen des Ordners ein, in dem Sie die Seiten der Website speichern möchten.
Geben Sie z. B. den Ordnernamen C:\WebSites\FormViewData ein.
Klicken Sie in der Liste Sprachen auf die Programmiersprache, in der Sie arbeiten möchten.
Klicken Sie auf OK.
Visual Web Developer erstellt den Ordner und die neue Seite Default.aspx.
Verwenden einer Dropdownliste als Master
In diesem Teil der exemplarischen Vorgehensweise fügen Sie einer Seite eine Dropdownliste hinzu und füllen diese mit einer Liste von Produktnamen. Wenn Benutzer ein Produkt auswählen, werden auf der Seite die Details für das Produkt in einem FormView-Steuerelement angezeigt.
So erstellen und füllen Sie eine Dropdownliste
Wechseln Sie zur Seite Default.aspx, oder öffnen Sie sie. Wenn Sie mit einer Website arbeiten, die Sie bereits erstellt haben, fügen Sie eine Seite hinzu oder öffnen Sie eine Seite, mit der Sie in dieser exemplarischen Vorgehensweise arbeiten können.
Wechseln Sie in die Entwurfsansicht.
Geben Sie Display Product Information in der Seite ein.
Ziehen Sie aus der Gruppe Standard der Toolbox ein DropDownList-Steuerelement auf die Seite.
Wenn das Kontextmenü DropDownList-Aufgaben nicht angezeigt wird, klicken Sie mit der rechten Maustaste auf das DropDownList-Steuerelement, und klicken Sie dann auf Smarttag anzeigen.
Aktivieren Sie im Menü DropDownList-Aufgaben das Kontrollkästchen AutoPostBack aktivieren.
Klicken Sie auf Datenquelle auswählen, um den Assistent zum Konfigurieren von Datenquellen zu öffnen.
Klicken Sie in der Liste Datenquelle wählen auf <Neue Datenquelle>.
Klicken Sie auf Datenbank.
Dies gibt an, dass Sie Daten aus einer Datenbank abrufen möchten, die SQL-Anweisungen unterstützt.
Im Feld ID für Datenquelle angeben wird ein Standardname für ein Datenquellen-Steuerelement angezeigt. Sie können diesen Namen beibehalten.
Klicken Sie auf OK.
Der Assistent zeigt eine Seite an, auf der Sie eine Verbindung auswählen können.
Klicken Sie auf die Schaltfläche Neue Verbindung.
Das Dialogfeld Verbindung hinzufügen wird angezeigt.
Wenn in der Liste Datenquelle der Eintrag Microsoft SQL Server (SqlClient) nicht angezeigt wird, klicken Sie auf Ändern, und wählen Sie im Dialogfeld Datenquelle wechseln den Eintrag Microsoft SQL Server aus.
Wenn die Seite Datenquelle auswählen angezeigt wird, wählen Sie in der Liste Datenquelle den Typ der zu verwendenden Datenquelle aus. Für diese exemplarische Vorgehensweise ist der Datenquellentyp Microsoft SQL Server. Klicken Sie in der Liste Datenanbieter auf .NET Framework-Datenanbieter für SQL Server, und klicken Sie danach auf Weiter.
Gehen Sie im Dialogfeld Verbindung hinzufügen wie folgt vor:
Geben Sie im Feld Servername den Namen des Computers ein, auf dem SQL Server ausgeführt wird.
Wählen Sie als Anmeldeinformationen die passende Option für die SQL Server-Datenbank aus (integrierte Sicherheit oder bestimmte ID und Kennwort), und geben Sie, wenn erforderlich, einen Benutzernamen und ein Kennwort ein. Aktivieren Sie das Kontrollkästchen Kennwort speichern, wenn Sie ein Kennwort eingegeben haben.
Wählen Sie die Schaltfläche Datenbanknamen auswählen oder eingeben aus, und geben Sie dann Northwind ein.
Klicken Sie auf Testverbindung, und wenn Sie sicher sind, dass die Verbindung funktioniert, klicken Sie auf OK.
Sie kehren zum Assistenten zurück, und die Verbindungsinformationen werden eingetragen.
Klicken Sie auf Weiter.
Vergewissern Sie sich, dass das Kontrollkästchen Ja, Verbindung speichern unter aktiviert ist, und klicken Sie dann auf Weiter. (Sie können den Namen der Standardverbindungszeichenfolge beibehalten.)
Der Assistent zeigt eine Seite an, auf der Sie angeben können, welche Daten Sie aus der Datenbank abrufen möchten.
Klicken Sie auf Spalten von Tabelle oder Ansicht angeben.
Klicken Sie in der Liste Name auf Products.
Unter Spalten wählen Sie ProductID und ProductName aus.
Klicken Sie auf Weiter.
Klicken Sie auf Testabfrage, um sicherzustellen, dass Sie die von Ihnen gewünschten Daten abrufen.
Klicken Sie auf Fertig stellen.
Sie kehren zum Assistenten zurück.
Klicken Sie in der Liste Datenfeld zur Anzeige in DropDownList auswählen auf ProductName.
In der Liste Datenfeld als Wert von DropDownList auswählen wählen Sie ProductID aus.
Dadurch geben Sie an, dass, wenn ein Element ausgewählt wird, das Feld ProductID als Wert des Elements zurückgegeben wird.
Klicken Sie auf OK.
Testen Sie die Dropdownliste, bevor Sie fortfahren.
So testen Sie die Dropdownliste
Drücken Sie STRG+F5, um die Seite auszuführen.
Wenn die Seite angezeigt wird, überprüfen Sie die Dropdownliste.
Wählen Sie einen Produktnamen aus, um sicherzustellen, dass die Liste ein Postback ausführt.
Hinzufügen eines FormView-Steuerelements
Sie fügen jetzt ein FormView-Steuerelement zum Anzeigen von Produktdetails hinzu. Das FormView-Steuerelement ruft seine Daten aus einem zweiten Datenquellen-Steuerelement ab, das Sie der Seite hinzufügen. Das zweite Datenquellen-Steuerelement enthält eine parametrisierte Abfrage, die den Produktdatensatz für das momentan im DropDownList-Steuerelement ausgewählte Element abruft.
So fügen Sie ein FormView-Steuerelement hinzu
Ziehen Sie aus der Gruppe Daten der Toolbox ein FormView-Steuerelement auf die Seite.
Wenn das Kontextmenü FormView-Aufgaben nicht angezeigt wird, klicken Sie mit der rechten Maustaste auf das FormView-Steuerelement, und klicken Sie dann auf Smarttag anzeigen.
Klicken Sie im Menü FormView-Aufgaben in der Liste Datenquelle auswählen auf <Neue Datenquelle>.
Das Dialogfeld Assistent zum Konfigurieren von Datenquellen wird angezeigt.
Klicken Sie auf Datenbank.
Das FormView-Steuerelement ruft Daten aus der gleichen Tabelle ab wie das DropDownList-Steuerelement.
Im Feld ID für Datenquelle angeben wird ein Standardname für ein Datenquellen-Steuerelement angezeigt. Sie können diesen Namen beibehalten.
Klicken Sie auf OK.
Der Assistent zum Konfigurieren von Datenquellen wird gestartet.
Wählen Sie aus der Liste Über welche Datenverbindung soll die Anwendung eine Verbindung mit der Datenbank herstellen? die Verbindung aus, die Sie früher in dieser exemplarischen Vorgehensweise erstellt und gespeichert haben.
Klicken Sie auf Weiter.
Der Assistent zeigt eine Seite an, auf der Sie eine SQL-Anweisung erstellen können.
Wählen Sie aus der Liste Name unter Spalten von Tabelle oder Ansicht angeben den Eintrag Products aus.
Im Feld Spalten wählen Sie ProductID, ProductName und UnitPrice aus.
Klicken Sie auf die Schaltfläche WHERE.
Das Dialogfeld WHERE-Klausel hinzufügen wird angezeigt.
Wählen Sie aus der Liste Spalte den Eintrag ProductID aus.
Wählen Sie in der Liste Operator den Eintrag = aus.
Wählen Sie aus der Liste Quelle den Eintrag Steuerelement aus.
Wählen Sie unter Parametereigenschaften in der Liste Steuerelement-ID den Eintrag DropDownList1 aus.
Durch die letzten beiden Schritte wird angegeben, dass die Abfrage den Suchwert für die Produkt-ID aus dem DropDownList-Steuerelement abruft, das Sie zuvor hinzugefügt haben.
Klicken Sie auf Hinzufügen.
Klicken Sie auf OK, um das Dialogfeld WHERE-Klausel hinzufügen zu schließen.
Klicken Sie auf Erweitert.
Das Dialogfeld Erweiterte SQL-Generierungsoptionen wird angezeigt.
Aktivieren Sie das Kontrollkästchen INSERT-, UPDATE- und DELETE-Anweisungen generieren.
Diese Option veranlasst den Assistenten, SQL-Aktualisierungsanweisungen basierend auf der von Ihnen konfigurierten Select-Anweisung zu erstellen. Später in dieser exemplarischen Vorgehensweise verwenden Sie das FormView-Steuerelement, um Datensätze zu bearbeiten und einzufügen. Dazu müssen für das Datenquellen-Steuerelement Aktualisierungsanweisungen zur Verfügung stehen.
Klicken Sie auf OK.
Klicken Sie auf Weiter.
Klicken Sie in der Seitenvorschau auf Testabfrage.
Der Assistent zeigt ein Dialogfeld an, in dem Sie zur Eingabe eines in der WHERE-Klausel zu verwendenden Werts aufgefordert werden.
Geben Sie 4 in das Feld Wert ein, und klicken Sie dann auf OK.
Die Produktinformationen werden angezeigt.
Klicken Sie auf Fertig stellen.
Anpassen des Layouts im FormView-Steuerelement
Sie können das FormView-Steuerelement verwenden, um das Layout des darin angezeigten Datensatzes anzupassen. In diesem Abschnitt der exemplarischen Vorgehensweise passen Sie das Datensatzlayout an, indem Sie eine Vorlage bearbeiten. Für das Layout verwenden Sie eine HTML-Tabelle.
So formatieren Sie das Layout
Klicken Sie auf das FormView-Steuerelement, um es auszuwählen, und ziehen Sie dann den Größenziehpunkt auf der rechten Seite des Steuerelements, um das Steuerelement auf die Breite der aktuellen Seite zu bringen.
Ziehen Sie den Größenziehpunkt an der Unterkante des Steuerelements, um die Höhe des Steuerelements auf etwa 400 Pixel zu ändern. (Die genaue Höhe ist nicht wichtig.)
Klicken Sie mit der rechten Maustaste auf das Steuerelement, klicken Sie auf Vorlage bearbeiten, und klicken Sie dann auf ItemTemplate.
Das Steuerelement wird im Elementvorlagen-Bearbeitungsmodus erneut angezeigt. Die Elementvorlage enthält den statischen Text und die Steuerelemente, die verwendet werden, um bei der Ausführung der Seite den Datensatz anzuzeigen. Visual Web Developer füllt normalerweise die Elementvorlage für jede Datenspalte in der Datenquelle mit einem datengebundenen Label-Steuerelement. Zusätzlich generiert Visual Web Developer für jede Bezeichnung statischen Text, der als Beschriftung fungiert.
Die Vorlage wird auch mit drei LinkButton-Steuerelementen generiert, die den Text Bearbeiten, Löschen und Neu enthalten.
Setzen Sie die Einfügemarke an den Beginn der Elementvorlage, drücken Sie mehrmals die EINGABETASTE, um Platz zu schaffen, und geben Sie dann am Beginn der Vorlage Product Details als Überschrift ein.
Setzen Sie den Cursor unter die Steuerelemente und den statischen Text, und klicken Sie im Menü Tabelle auf Tabelle einfügen.
Sie erstellen eine HTML-Tabelle als Container für den Text und die Steuerelemente.
Legen Sie im Dialogfeld Tabelle einfügen die Option Zeilen auf 4 und die Option Spalten auf 2 fest.
Klicken Sie auf OK, um das Dialogfeld Tabelle einfügen zu schließen.
Markieren Sie alle Zellen der Tabelle, und wählen Sie anschließend im Menü Tabelle den Punkt Zellformatierung aus.
Das Dialogfeld Zelleneigenschaften wird angezeigt.
Legen Sie die Breite auf 35 Pixel (px) und die Höhe auf 30 Pixel (px) fest.
Klicken Sie auf OK, um das Dialogfeld Zelleneigenschaften zu schließen.
Ziehen Sie das ProductIdLabel-Steuerelement in die oberste Zelle auf der rechten Seite.
Ziehen Sie das ProductNameLabel-Steuerelement in die zweite Zelle auf der rechten Seite.
Ziehen Sie das UnitPriceLabel-Steuerelement in die dritte Zelle auf der rechten Seite.
Geben Sie in der linken Spalte statischen Text ein, der als Beschriftung für die Label-Steuerelemente fungiert. Geben Sie z. B. in der Zelle neben dem ProductIdLabel-Steuerelement ID ein. Sie können einen beliebigen Beschriftungstext eingeben.
Klicken Sie mit der rechten Maustaste auf die linke Spalte, klicken Sie auf Auswählen, und klicken Sie dann auf Spalte.
Legen Sie im Eigenschaftenfenster Ausrichten auf Rechts fest, damit der Beschriftungstext rechtsbündig wird.
Wählen Sie die rechte Spalte aus, und ziehen Sie an deren rechtem Rand, damit die Tabelle breit genug ist, dass in ihr auch lange Produktnamen angezeigt werden können.
Wählen Sie den von Visual Web Developer generierten Text aus (z. B. den Text ProductID), und löschen Sie ihn.
Klicken Sie mit der rechten Maustaste auf die Titelleiste des FormView-Steuerelements, und klicken Sie auf Vorlagenbearbeitung beenden.
Der Vorlagen-Editor wird geschlossen, und das Steuerelement wird mit dem Layout angezeigt, das Sie erstellt haben.
Testen des FormView-Steuerelements
Sie können das Layout jetzt testen.
So testen Sie das FormView-Steuerelement
Drücken Sie STRG+F5, um die Seite auszuführen.
Klicken Sie im DropDownList-Steuerelement auf einen Produktnamen.
Im FormView-Steuerelement werden Details zu diesem Produkt angezeigt.
Wählen Sie ein anderes Produkt aus, und überprüfen Sie, dass im FormView-Steuerelement die Produktdetails angezeigt werden.
Schließen Sie den Browser.
Hinzufügen der Funktionen zum Bearbeiten und Einfügen zum FormView-Steuerelement
Im FormView-Steuerelement können einzelne Datensätze angezeigt werden. Es unterstützt aber auch das Bearbeiten, Löschen und Einfügen.
In diesem Teil der exemplarischen Vorgehensweise fügen Sie die Funktion zum Bearbeiten des aktuell angezeigten Datensatzes hinzu. Wenn Sie den Datensatz bearbeiten möchten, definieren Sie eine andere Vorlage, die Textfelder (und potenziell andere Steuerelemente) enthält.
So fügen Sie dem FormView-Steuerelement Funktionen zum Bearbeiten hinzu
Klicken Sie mit der rechten Maustaste auf das FormView-Steuerelement, klicken Sie auf Vorlage bearbeiten, und klicken Sie auf EditItemTemplate.
Der Vorlagen-Editor wird angezeigt und in diesem die EditItemTemplate-Eigenschaft, mit der das Layout der Datensätze definiert wird, die sich im Bearbeitungsmodus befinden. Visual Web Developer füllt die Bearbeitungsvorlage mit einem TextBox-Steuerelement für jede Datenspalte, die keine Schlüsselspalte ist, und fügt statischen Text für Beschriftungen hinzu. Dies entspricht dem Verfahren, mit dem die Elementvorlage generiert wurde, jedoch mit dem Unterschied, dass Visual Web Developer in der Bearbeitungsvorlage Textfelder generiert.
Wie schon zuvor wird die Vorlage mit den LinkButton-Steuerelementen Aktualisieren und Abbrechen generiert, mit denen Änderungen während der Bearbeitung gespeichert oder verworfen werden können.
Fügen Sie optional eine Layouttabelle hinzu, und ordnen Sie die Steuerelemente so an, wie dies zuvor in dieser exemplarischen Vorgehensweise beim Arbeiten mit der Elementvorlage erfolgt ist.
Klicken Sie mit der rechten Maustaste auf das FormView-Steuerelement, klicken Sie auf Vorlage bearbeiten, und klicken Sie dann auf InsertItemTemplate.
Wie bei der EditItemTemplate-Eigenschaft erstellt Visual Web Developer automatisch ein Vorlagenlayout für Bezeichnungen und TextBox-Steuerelemente. Die Steuerelemente werden angezeigt, wenn Benutzer einen neuen Datensatz in die Produkttabelle einfügen möchten. Die Vorlage wird auch bei den LinkButton-Steuerelementen Einfügen und Abbrechen generiert.
Fügen Sie optional eine Layouttabelle hinzu, und ordnen Sie die Steuerelemente so an, wie Sie dies beim Arbeiten mit der Bearbeitungselementvorlage getan haben.
Klicken Sie mit der rechten Maustaste auf das FormView-Steuerelement, und klicken Sie auf Vorlagenbearbeitung beenden.
Sicherheitshinweis: Benutzereingaben auf einer ASP.NET-Webseite können möglicherweise schädliche Clientskripts enthalten. Standardmäßig wird die Benutzereingabe von ASP.NET-Webseiten überprüft, damit die Eingabe keine Skript- oder HTML-Elemente enthält. Solange die Validierung aktiviert ist, müssen Sie Benutzereingaben nicht explizit auf Skripts oder HTML-Elemente überprüfen. Weitere Informationen finden Sie unter Übersicht über Skriptangriffe.
Testen der Funktionen zum Bearbeiten und Einfügen
Sie können jetzt die Funktionen zum Bearbeiten und Einfügen testen.
So testen Sie die Bearbeitungsfunktionen des FormView-Steuerelements
Drücken Sie STRG+F5, um die Seite auszuführen.
Wählen Sie im DropDownList-Steuerelement ein Produkt aus.
Die Produktdetails werden im FormView-Steuerelement angezeigt.
Klicken Sie auf Bearbeiten.
Das FormView-Steuerelement wechselt in den Bearbeitungsmodus.
Nehmen Sie eine Änderung am Produktnamen oder am Einzelpreis vor.
Klicken Sie auf Aktualisieren.
Der Datensatz wird gespeichert, und das FormView-Steuerelement wechselt in den Anzeigemodus. Die Änderung wird in der Anzeige reflektiert.
Wählen Sie ein anderes Produkt aus.
Klicken Sie auf Bearbeiten.
Nehmen Sie eine Änderung am Produktnamen vor.
Klicken Sie auf Abbrechen.
Überprüfen Sie, ob die Änderung nicht gespeichert wurde.
So testen Sie die Einfügefunktionen des FormView-Steuerelements
Klicken Sie im FormView-Steuerelement auf Neu.
Das FormView-Steuerelement wechselt in den Einfügemodus. Dabei werden zwei leere Textfelder angezeigt.
Geben Sie einen neuen Produktnamen und einen Preis ein, und klicken Sie dann auf Einfügen.
Der Datensatz wird in der Datenbank gespeichert, und das FormView-Steuerelement wechselt in die Anzeigeansicht (ItemTemplate).
Hinweis: Der neue Datensatz wird in der Dropdownliste nicht angezeigt. Sie fügen diese Funktion im nächsten Abschnitt hinzu.
Erneutes Anzeigen von aktualisierten Produktnamen in der Dropdownliste
Auf dieser Seite können Sie jetzt Datensätze in der Datenbanktabelle Products anzeigen, bearbeiten oder löschen. Die Dropdownliste wird aber noch nicht mit den Änderungen synchronisiert, die Sie im FormView-Steuerelement vornehmen. Wenn Sie beispielsweise einen neuen Produktdatensatz einfügen, wird der neue Datensatz erst in der Dropdownliste angezeigt, wenn Sie die Seite schließen und erneut öffnen. Außerdem wird die Seite am Anfang mit dem ersten Datensatz in der Produkttabelle angezeigt. Dies entspricht möglicherweise nicht Ihren Anforderungen.
Sie können Code hinzufügen, um diese kleineren Probleme zu beheben. In diesem Abschnitt der exemplarischen Vorgehensweise führen Sie Folgendes aus:
Aktualisieren der Dropdownliste, wenn Benutzer einen Datensatz bearbeiten oder einfügen.
Hinzufügen des Texts "(Select)" zur Dropdownliste, wenn die Seite das erste Mal angezeigt wird, und Entfernen des Texts, wenn der Benutzer seine erste Auswahl getroffen hat.
So aktualisieren Sie die Dropdownliste, wenn Datensätze bearbeitet oder eingefügt werden
Wählen Sie in der Entwurfsansicht der Seite das FormView-Steuerelement aus.
Klicken Sie im Eigenschaftenfenster auf die Schaltfläche Ereignisse, um eine Liste von Ereignissen für das FormView-Steuerelement anzuzeigen.
Doppelklicken Sie auf das Feld ItemInserted.
Visual Web Developer wechselt in die Codebearbeitungsansicht und erstellt einen Handler für das ItemInserted-Ereignis.
Fügen Sie dem Ereignishandler den folgenden hervorgehobenen Code hinzu.
Protected Sub FormView1_ItemInserted(ByVal sender As Object, _ ByVal e As System.Web.UI.WebControls.FormViewInsertedEventArgs) _ Handles FormView1.ItemInserted DropDownList1.DataBind() End Sub
[C#]
protected void FormView1_ItemInserted(object sender, FormViewInsertedEventArgs e) { DropDownList1.DataBind(); }
Der Code wird ausgeführt, nachdem der neue Datensatz eingefügt wurde. Die Dropdownliste wird erneut an die Produkttabelle gebunden. Dies führt zu einer Aktualisierung des Inhalts der Liste.
Wechseln Sie in die Entwurfsansicht. (Wenn Sie mit einer Code-Behind-Seite arbeiten, schalten Sie zur Seite Default.aspx um, und wechseln Sie danach in die Entwurfsansicht.)
Klicken Sie im Eigenschaftenfenster auf die Schaltfläche Ereignisse, um eine Liste von Ereignissen für das FormView-Steuerelement anzuzeigen.
Doppelklicken Sie auf das Feld ItemUpdated.
Visual Web Developer wechselt in die Codebearbeitungsansicht und erstellt einen Ereignishandler für das ItemUpdated-Ereignis.
Fügen Sie den folgenden hervorgehobenen Code hinzu.
Protected Sub FormView1_ItemUpdated(ByVal sender As Object, _ ByVal e As System.Web.UI.WebControls.FormViewUpdatedEventArgs) _ Handles FormView1.ItemUpdated DropDownList1.DataBind() End Sub
[C#]
protected void FormView1_ItemUpdated(object sender, FormViewUpdatedEventArgs e) { DropDownList1.DataBind(); }
Der Code wird ausgeführt, nachdem der Datensatz aktualisiert wurde. Die Dropdownliste wird erneut an die Produkttabelle gebunden. Dies führt zu einer Aktualisierung des Inhalts der Liste.
Drücken Sie STRG+F5, um die Seite auszuführen.
Geben Sie den Produktnamen eines Datensatzes ein, klicken Sie auf Aktualisieren, und überprüfen Sie dann die Dropdownliste, um sich zu vergewissern, dass der aktualisierte Name angezeigt wird.
Fügen Sie einen neuen Produktdatensatz ein, klicken Sie auf Einfügen, und überprüfen Sie dann die Dropdownliste, um sich zu vergewissern, dass der Liste der neue Name hinzugefügt wurde.
Im abschließenden Schritt müssen Sie die Dropdownliste so ändern, dass "(Select)" angezeigt wird und dass das FormView-Steuerelement nur angezeigt wird, wenn Benutzer eine Auswahl getroffen haben.
So fügen Sie dem DropDownList-Steuerelement einen Auswahleintrag hinzu
Doppelklicken Sie in der Entwurfsansicht auf einen leeren Teil der Seite.
Visual Web Developer erstellt einen Ereignishandler für das Load-Ereignis der Seite.
Fügen Sie im Handler folgenden hervorgehobenen Code hinzu:
[Visual Basic]
Protected Sub Page_Load(ByVal sender As Object, _ ByVal e As System.EventArgs) Handles Me.Load If Not IsPostBack Then FormView1.Visible = False End If End Sub
[C#]
protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { FormView1.Visible = false; } }
Der Code wird beim Ausführen der Seite ausgeführt. Dabei wird zuerst getestet, ob es sich um ein Postback handelt. Sollte das nicht der Fall sein, wird die Seite das erste Mal ausgeführt. Wenn es sich nicht um ein Postback handelt, wird das FormView-Steuerelement durch den Code ausgeblendet, da es nur angezeigt werden soll, wenn der Benutzer explizit einen Datensatz zum Ansehen oder Bearbeiten ausgewählt hat.
Wählen Sie in der Entwurfsansicht der Seite das DropDownList-Steuerelement aus.
Klicken Sie im Eigenschaftenfenster im Feld Elemente auf das Auslassungszeichen (...).
Das Dialogfeld ListItem-Auflistungs-Editor wird angezeigt.
Klicken Sie auf Hinzufügen, um ein neues Element zu erstellen.
Geben Sie unter ListItem-Eigenschaften im Feld Text den Text (Select) ein.
Klicken Sie auf OK, um das Dialogfeld ListItem-Auflistungs-Editor zu schließen.
Legen Sie im Feld Eigenschaften AppendDataBoundItems auf true fest.
Wenn die Dropdownliste während der Datenbindung gefüllt wird, werden die Produktinformationen dem von Ihnen definierten (Select)-Element hinzugefügt.
Klicken Sie im Eigenschaftenfenster auf die Schaltfläche Ereignisse, um eine Liste von Ereignissen für das DropDownList-Steuerelement anzuzeigen.
Doppelklicken Sie auf das Feld SelectedIndexChanged.
Fügen Sie den folgenden hervorgehobenen Code hinzu.
[Visual Basic]
Protected Sub DropDownList1_SelectedIndexChanged(ByVal sender _ As Object, ByVal e As System.EventArgs) _ Handles DropDownList1.SelectedIndexChanged If DropDownList1.Items(0).Text = "(Select)" Then DropDownList1.Items.RemoveAt(0) End If FormView1.Visible = True End Sub
[C#]
protected void DropDownList1_SelectedIndexChanged(object sender, EventArgs e) { if(DropDownList1.Items[0].Text == "(Select)") { DropDownList1.Items.RemoveAt(0); } FormView1.Visible = true; }
Der Code wird ausgeführt, wenn Benutzer ein Element im DropDownList-Steuerelement auswählen. Nachdem sichergestellt wurde, dass das zuvor hinzugefügte "(Select)"-Element vorhanden ist, wird dieses entfernt, da Benutzer nicht mehr zur Auswahl eines Elements aufgefordert werden müssen, nachdem sie erstmals ein Element ausgewählt haben. Durch den Code wird auch das FormView-Steuerelement angezeigt (nicht mehr ausgeblendet), sodass Benutzern der von ihnen ausgewählte Datensatz angezeigt wird.
Drücken Sie STRG+F5, um die Seite auszuführen.
Auf der Seite wird nur die Dropdownliste angezeigt, wobei das Wort (Select) angezeigt wird.
Wählen Sie ein Element in der Liste aus.
Das Element wird im FormView-Steuerelement angezeigt.
Überprüfen Sie die Dropdownliste, und beachten Sie, dass sich das Wort (Select) nicht mehr in der Liste befindet.
Nächste Schritte
In dieser exemplarischen Vorgehensweise wurden Ihnen die grundlegenden Schritte zur Verwendung eines FormView-Steuerelements zum Anzeigen und Bearbeiten einzelner Datensätze mit einem benutzerdefinierten Layout veranschaulicht. Mit dem FormView-Steuerelement können Sie auch eine anspruchsvollere Formatierung ausführen, als Sie dies in dieser exemplarischen Vorgehensweise getan haben. Außerdem können Sie Vorlagen für andere Modi, einschließlich Auswahlmodus und Einfügemodus, sowie für Header und Footer erstellen, die zusammen mit dem Datensatz angezeigt werden. Andere Szenarien, in denen die FormView verwendet werden kann, finden Sie unter:
Erstellen von Vorlagen für das FormView-Webserversteuerelement
Ändern von Daten mithilfe eines FormView-Webserversteuerelements
Siehe auch
Konzepte
Übersicht über das FormView-Webserversteuerelement