Sdílet prostřednictvím


Exemplarische Vorgehensweise: Erstellen einer AJAX-fähigen Datenanwendung

Aktualisiert: November 2007

In dieser exemplarischen Vorgehensweise wird beschrieben, wie Sie eine AJAX-fähige Webanwendung erstellen, die als Aufgabenliste eingesetzt werden kann. Die Anwendung unterstützt Sie beim Erstellen einer grundlegenden Benutzeroberfläche zum Erstellen, Verwalten und Löschen von Listen und der darin enthaltenen Einträge. Sämtliche Schritte in Verbindung mit den Vorgängen Einfügen, Aktualisieren, Löschen, Sortieren und Paging werden innerhalb eines UpdatePanel-Steuerelements ausgeführt, das AJAX verwendet.

Sie können das UpdatePanel-Steuerelement verwenden, um asynchrone Postbacks auf einer Seite zu aktivieren. Standardmäßig aktualisiert ASP.NET die ganze Seite, wenn ein Postback auftritt. Wenn Sie jedoch das UpdatePanel-Steuerelement zum Erstellen von asynchronen Postbacks verwenden, werden nur die Seitenelemente geändert, die sich innerhalb des UpdatePanel-Steuerelements befinden. Dies bewirkt eine dynamischere und schnellere Verarbeitung der Seite sowie eine bessere Benutzererfahrung.

In dieser exemplarischen Vorgehensweise werden u. a. die folgenden Aufgaben veranschaulicht:

  • Erstellen einer SQL-Datenbank und Hinzufügen von Daten

  • Hinzufügen eines LinqDataSource-Steuerelements zu einer Seite

  • Hinzufügen einer LINQ to SQL-Klassen-Datei.

  • Verwenden des ListView-Steuerelements zum Anzeigen, Bearbeiten und Löschen von Daten

  • Verwenden des LinqDataSource-Steuerelements, um mithilfe der sprachintegrierten Abfrage (Language Integrated Query, LINQ) eine Verbindung zu einer Datenbank herzustellen. Weitere Informationen finden Sie unter Sprachintegrierte Abfrage (Language-Integrated Query, LINQ).

  • Verwenden des UpdatePanel-Steuerelements zum Hinzufügen von AJAX-Funktionalität zur Seite

Vorbereitungsmaßnahmen

Zum Durchführen der exemplarischen Vorgehensweise benötigen Sie Folgendes:

  • Microsoft Visual Studio 2008 oder Visual Web Developer 2008 Express Edition. Informationen zum Herunterladen finden Sie auf der Website Visual Studio Development Center (möglicherweise in englischer Sprache).

  • Eine auf dem Computer installierte SQL Server Express Edition. Sie können auch eine SQL Server-Installation verwenden, jedoch müssen Sie an einigen Prozeduren kleine Anpassungen vornehmen.

Erstellen einer Website

In diesem Teil der exemplarischen Vorgehensweise erstellen Sie eine Website und fügen dieser eine Seite hinzu. Im nächsten Abschnitt stellen Sie eine Verbindung zu einer Datenbank her. Wenn Sie bereits eine Website erstellt haben (z. B. indem Sie die Schritte unter Exemplarische Vorgehensweise: Erstellen einer einfachen Webseite in Visual Web Developer befolgt haben), können Sie diese Website in dieser exemplarischen Vorgehensweise verwenden. Erstellen Sie andernfalls eine neue Website, indem Sie folgende Schritte ausführen.

So erstellen Sie eine neue Dateisystem-Website

  1. Klicken Sie in Visual Web Developer im Menü Datei auf Neue Website.

    Das Dialogfeld Neue Website wird angezeigt.

  2. Klicken Sie unter Von Visual Studio installierte Vorlagen auf ASP.NET-Website.

  3. Klicken Sie im Feld Speicherort auf Dateisystem, und geben Sie den Namen des Ordners ein, in dem Sie die Seiten der Website speichern möchten.

  4. Klicken Sie im Listenfeld Sprache auf Visual Basic oder Visual C#, und klicken Sie dann auf OK.

    Bb763182.alert_note(de-de,VS.90).gifHinweis:

    Die gewählte Programmiersprache wird zur Standardsprache für die Website. Sie können jedoch die Programmiersprache für jede Seite einzeln festlegen.

    Visual Web Developer erstellt den Ordner und die neue Seite Default.aspx.

Erstellen einer neuen SQL Server-Datenbank

Nachdem Sie jetzt über eine Website verfügen, besteht der nächste Schritt darin, eine Datenbank zu erstellen und im Server-Explorer einen Verweis auf die Datenbank hinzuzufügen. (In Visual Web Developer 2008 Express Edition hat der Server-Explorer den Namen Datenbank-Explorer.) Wenn Sie dem Server-Explorer eine Datenbank hinzufügen, können Sie Visual Studio verwenden, um Tabellen, gespeicherte Prozeduren, Ansichten usw. hinzuzufügen. Außerdem können Sie Tabellendaten anzeigen oder manuell bzw. grafisch eigene Abfragen erstellen, indem Sie das Fenster Abfrage-Generator verwenden.

So fügen Sie dem Projekt eine Datenbank hinzu

  1. Klicken Sie im Projektmappen-Explorer mit der rechten Maustaste auf den Namen der Website, und klicken Sie dann auf Neues Element hinzufügen.

    Das Dialogfeld Neues Element hinzufügen wird angezeigt.

  2. Wählen Sie SQL-Datenbank, geben Sie der Datenbank den Namen Tasks.mdf, und klicken Sie auf OK.

  3. Klicken Sie auf Ja, wenn Visual Studio Sie fragt, ob die Datenbank im Ordner App_Data gespeichert werden soll.

Erstellen eines Schemas und von Beispieldaten für die Datenbank

Sie können die Entwurfs- und Bearbeitungsfunktionen der Datenbank verwenden, um ein Schema für die neue Tabelle zu erstellen, in der die Aufgabenelemente gespeichert sind.

So erstellen Sie ein Schema und Beispieldaten für die Datenbank

  1. Öffnen Sie im Projektmappen-Explorer den Ordner App_Data, und doppelklicken Sie auf Tasks.mdf.

    Die hierarchische Struktur der Aufgabendatenbank wird im Server-Explorer (bzw. Datenbank-Explorer) angezeigt.

  2. Klicken Sie mit der rechten Maustaste auf den Ordner Tabellen, und klicken Sie auf Neue Tabelle hinzufügen.

  3. Erstellen Sie im Datenbanktabellen-Editor die folgenden Spalten für die Tabelle:

    Spaltenname

    Datentyp

    Eigenschaften

    taskId

    int

    NULL zulassen: Nein

    taskName

    nvarchar(50)

    NULL zulassen: Nein

    dateCreated

    DateTime

    NULL zulassen: Nein

    isComplete

    bit

    NULL zulassen: Nein

  4. Klicken Sie mit der rechten Maustaste auf die Zeile, die den Eintrag taskid enthält, und klicken Sie dann auf Primärschlüssel festlegen.

  5. Öffnen Sie bei aktivierter taskid-Zeile auf der Registerkarte Spalteneigenschaften den Abschnitt Identitätsspezifikation, und setzen Sie (Ist Identity) auf Ja.

  6. Speichern Sie die Tabelle unter dem Namen TasksList.

  7. Klicken Sie im Server-Explorer mit der rechten Maustaste auf die Tabelle, und klicken Sie auf Tabellendaten anzeigen.

    Es wird ein Fenster angezeigt, in dem Sie die Daten anzeigen und hinzufügen können.

  8. Fügen Sie der Tabelle vier oder fünf Datensätze hinzu, und schließen Sie dann den Datenbank-Designer.

    Sie müssen für taskId keinen Wert angeben, da es sich um eine Identitätsspalte handelt, deren Wert automatisch zugewiesen wird. Sie müssen für das isComplete-Feld entweder False oder True angeben.

Erstellen der Steuerelemente für den Datenzugriff

In diesem Abschnitt verwenden Sie das LinqDataSource-Steuerelement und erstellen Klassen, die Datenbankentitäten darstellen. Beim Steuerelement und den erstellten Klassen handelt es sich um die Datenzugriffsschicht, die in dieser exemplarischen Vorgehensweise verwendet wird.

Das LinqDataSource-Steuerelement stellt LINQ (Language-Integrated Query, sprachintegrierte Abfrage) mithilfe der ASP.NET-Datenquellensteuerelement-Architektur für Webentwickler bereit. Das LinqDataSource-Steuerelement erstellt den Code zum Auswählen, Einfügen, Aktualisieren und Löschen von Objekten in der Datenbank. LINQ wendet die Prinzipien der objektorientierten Programmierung auf relationale Daten an. LINQ stellt ein einheitliches Programmiermodell zum Abfragen und Aktualisieren von Daten aus verschiedenen Datenquellentypen bereit und erweitert direkt die Datenfunktionen der Sprachen C# und Visual Basic. Weitere Informationen zu LINQ finden Sie unter Sprachintegrierte Abfrage (Language-Integrated Query, LINQ).

Zuordnen der Aufgabendatenbank zu einem SQL-Datenkontextobjekt

Um mit dem Erstellen der Datenzugriffsschicht zu beginnen, fügen Sie dem Projekt ein typisiertes Dataset hinzu.

So erstellen Sie eine Klasse für die TasksList-Tabelle

  1. Wenn die Website nicht bereits über den Ordner App_Code verfügt, klicken Sie im Projektmappen-Explorer mit der rechten Maustaste auf den Namen der Website, klicken Sie auf ASP.NET-Ordner hinzufügen, und klicken Sie dann auf App_Code.

  2. Klicken Sie mit der rechten Maustaste auf den Ordner App_Code, und klicken Sie dann auf Neues Element hinzufügen.

  3. Wählen Sie unter Von Visual Studio installierte Vorlagen die Vorlage LINQ to SQL-Klassen aus, benennen Sie die Datei in Tasks.dbml um, und klicken Sie dann auf Hinzufügen.

    Der O/R-Designer wird angezeigt.

  4. Ziehen Sie im Server-Explorer die Tabelle TasksList ins Fenster O/R-Designer.

  5. Speichern Sie die Datei Tasks.dbml.

    Wenn Sie die Datei speichern, erstellt Visual Studio im Ordner App_Code unter Tasks.dbml zwei Dateien. Die erste Datei ist Tasks.dbml.layout. Die zweite Datei ist Tasks.designer.cs oder Tasks.designer.vb. Dies hängt davon ab, welche Sprache Sie beim Erstellen der Datei Tasks.dbml gewählt haben.

  6. Öffnen Sie im Projektmappen-Explorer die Datei Tasks.designer.cs bzw. Tasks.designer.vb.

    Beachten Sie, dass der Code Klassen mit den Namen TasksDataContext und TasksList enthält. Die TasksDataContext-Klasse stellt die Datenbank dar, und die TasksList stellt die Datenbanktabelle dar. Der parameterlose Konstruktor für die TasksDataContext-Klasse liest die Verbindungszeichenfolge aus der Datei Web.config.

  7. Öffnen Sie die Datei Web.config.

    Beachten Sie, dass im connectionStrings-Element eine Verbindungszeichenfolge für die Datenbank Tasks.mdf hinzugefügt wurde.

  8. Schließen Sie die Klassendatei, das Fenster O/R-Designer und die Datei Web.config.

Erstellen und Konfigurieren eines LinqDataSource-Steuerelements

Da Sie nun über eine Datenbanktabelle und über Klassen verfügen, die Datenbankentitäten darstellen, können Sie auf einer ASP.NET-Webseite mit einem LinqDataSource-Steuerelement auf die Datenbank zugreifen.

So erstellen und konfigurieren Sie ein LinqDataSource-Steuerelement

  1. Öffnen Sie die Seite Default.aspx, oder wechseln Sie zu dieser Seite.

  2. Wechseln Sie in die Entwurfsansicht.

  3. Ziehen Sie ein LinqDataSource-Steuerelement auf die Seite.

    Sie können für die ID-Eigenschaft den Wert LinqDataSource1 übernehmen.

  4. Klicken Sie im Smarttagbereich LinqDataSource-Aufgaben auf Datenquelle konfigurieren.

    Bb763182.alert_note(de-de,VS.90).gifHinweis:

    Wenn der Smarttagbereich nicht angezeigt wird, klicken Sie mit der rechten Maustaste auf das LinqDataSource-Steuerelement und anschließend auf Smarttag anzeigen.

  5. Wählen Sie in der Liste Kontextobjekt auswählen den Eintrag TasksDataContext aus, und klicken Sie dann auf Weiter.

  6. Wählen Sie in der Liste Tabelle den Eintrag TasksLists(Table<TasksList>) aus, und klicken Sie dann auf Fertig stellen.

  7. Wählen Sie im Menü LinqDataSource-Aufgaben die Optionen Löschen aktivieren, Einfügen aktivieren und Aktualisieren aktivieren aus.

    Beachten Sie, dass Sie keine Datenbankbefehle zum Auswählen der Daten angeben müssen.

  8. Speichern Sie die Seite.

Verwenden der Datenquellensteuerelemente

In diesem Abschnitt fügen Sie der Seite Steuerelemente hinzu, die die LINQ to SQL-Klassendatei verwenden, über die die Datenbanktabelle den Klassen zugeordnet ist. Außerdem verwenden Sie das LinqDataSource-Steuerelement, um eine grundlegende Datenanwendung zu erstellen.

Sie fügen ein ListView-Steuerelement hinzu, um Daten aus einer SQL Server-Datenbank anzuzeigen. Anschließend fügen Sie ein DropDownList-Steuerelement hinzu, um die Daten zu filtern, die im ListView-Steuerelement angezeigt werden. Im weiteren Verlauf der exemplarischen Vorgehensweise fügen Sie die Steuerelemente in ein UpdatePanel-Steuerelement ein, um die Funktionen für asynchrone Postbacks hinzuzufügen.

Anzeigen von Daten mit einem ListView-Steuerelement

Das ListView-Steuerelement ist besonders zum Anzeigen von Daten mit sich wiederholenden Strukturen geeignet, vergleichbar mit den Steuerelementen DataList und Repeater. Im Gegensatz zu diesen Steuerelementen werden vom ListView-Steuerelement jedoch Vorgänge zum Bearbeiten, Einfügen und Löschen sowie Sortieren und Paging unterstützt.

Sie fügen ein ListView-Steuerelement hinzu, das alle Aufgaben anzeigt. Später fügen Sie eine Dropdownliste hinzu, mit der Sie die Daten filtern können. Das ListView-Steuerelement formatiert die Darstellung der Daten und zeigt Schaltflächen an, mit denen der Inhalt bearbeitet und aktualisiert bzw. neuer Inhalt eingefügt werden kann.

So fügen Sie der Seite ein ListView-Steuerelement hinzu

  1. Öffnen Sie die Seite bzw. wechseln Sie auf die Seite, auf der Sie das LinqDataSource-Steuerelement hinzugefügt haben.

  2. Ziehen Sie aus der Registerkarte Daten der Symbolleiste ein ListView-Steuerelement auf die Seite.

  3. Wählen Sie im Menü ListView-Aufgaben in der Liste Datenquelle auswählen den Eintrag LinqDataSource1 aus.

    Dadurch wird ListView an das LinqDataSource-Steuerelement gebunden, das Sie weiter oben in der exemplarischen Vorgehensweise konfiguriert haben.

  4. Klicken Sie im Smarttagbereich ListView-Aufgaben auf ListView konfigurieren.

  5. Wählen Sie im Dialogfeld ListView konfigurieren die Optionen Bearbeiten aktivieren, Einfügen aktivieren, Löschen aktivieren und Paging aktivieren aus.

  6. Klicken Sie auf OK.

  7. Speichern Sie die Seite.

Hinzufügen eines DropDownList-Steuerelements zum Filtern von Daten

Sie können die Daten filtern, die im ListView-Steuerelement angezeigt werden, indem Sie eine Dropdownliste erstellen, in der Sie die anzuzeigenden Aufgaben auswählen können. Für dieses Beispiel erstellen Sie eine Liste, in der entweder aktive Aufgaben oder abgeschlossene Aufgaben angezeigt werden.

Sie können Code in das ListView-Steuerelement einfügen, um automatisch eine Where-Klausel zu generieren und nur die Datensätze anzuzeigen, die mit der Auswahl im DropDownList-Steuerelement übereinstimmen.

So fügen Sie ein Steuerelement zum Filtern von Daten hinzu

  1. Öffnen Sie die Seite Default.aspx bzw. wechseln Sie zu dieser Seite, und wechseln Sie in die Quellansicht.

  2. Fügen Sie innerhalb des form-Elements und oberhalb des ListView-Steuerelements das folgende Markup hinzu:

    <span id="filter">
      Current List Filter: 
      <asp:DropDownList ID="DropDownList1" 
        AutoPostBack="true" 
        runat="server">
      <asp:ListItem Text="Active" Value="False" />
      <asp:ListItem Text="Completed" Value="True" />
      </asp:DropDownList>
    </span>
    <hr id="separator" />
    
  3. Setzen Sie die AutoGenerateWhereClause-Eigenschaft im LinqDataSource-Steuerelement auf true. Dies ist im folgenden Beispiel gezeigt:

    <asp:LinqDataSource ID="LinqDataSource1" runat="server" 
      ContextTypeName="TasksDataContext" 
      TableName="TasksLists" 
      EnableDelete="True" 
      EnableInsert="True" 
      EnableUpdate="True" 
      AutoGenerateWhereClause="true" >
    
  4. Fügen Sie das folgende Markup für Where-Parameter zwischen dem öffnenden und schließenden Tag des LinqDataSource-Steuerelements hinzu.

    <WhereParameters>
      <asp:ControlParameter 
        Name="isComplete" 
        ControlID="DropDownList1" 
        Type="Boolean" />
    </WhereParameters>
    
  5. Speichern Sie die Seite.

Sie können die Seite jetzt testen, um sicherzustellen, dass sie die gewählten Daten anzeigt.

So testen Sie die Seite

  1. Drücken Sie STRG+F5, um die Seite im Browser anzuzeigen.

  2. Wählen Sie aus der Dropdownliste die Option Abgeschlossen aus.

    Wenn Aufgaben vorhanden sind, die als abgeschlossen gekennzeichnet sind, werden nur diese Aufgaben aufgeführt.

Hinzufügen von AJAX-Funktionalität zur Seite

In diesem Abschnitt fügen Sie der Seite ein ScriptManager-Steuerelement hinzu, um die AJAX-Features von ASP.NET zu aktivieren. Anschließend fügen Sie der Seite ein UpdatePanel-Steuerelement hinzu, mit dem Sie Aufgaben im ListView-Steuerelement ausführen können, ohne dass ein Postback für die gesamte Seite erforderlich ist.

Hinzufügen eines ScriptManager-Steuerelements

Um ASP.NET-AJAX-Features wie das UpdatePanel-Steuerelement verwenden zu können, müssen Sie der Seite ein ScriptManager-Steuerelement hinzufügen.

So fügen Sie der Seite ein ScriptManager-Steuerelement hinzu

  1. Öffnen Sie die Seite Default.aspx bzw. wechseln Sie zu dieser Seite, und wechseln Sie in die Quellansicht.

  2. Doppelklicken Sie in der Toolbox auf der Registerkarte AJAX-Erweiterungen auf das ScriptManager-Steuerelement, um es der Seite im form-Element hinzuzufügen.

Einfügen des ListView-Steuerelements in ein UpdatePanel-Steuerelement

In diesem Beispiel fügen Sie ListView in ein UpdatePanel-Steuerelement ein. Änderungen des ListView-Steuerelements erfordern kein vollständiges Postback.

So fügen Sie das ListView-Steuerelement in ein UpdatePanel-Steuerelement ein

  1. Fügen Sie auf der Seite Default.aspx direkt nach dem öffnenden <form>-Tag das folgende Markup hinzu:

    <asp:UpdatePanel ID="UpdatePanel1" runat="server">
    <ContentTemplate>
    
  2. Fügen Sie direkt vor dem schließenden </form>-Tag den folgenden Code hinzu:

    </ContentTemplate>
    </asp:UpdatePanel>
    

    Dieser Code umschließt das ListView-Steuerelement und das DropDownList-Steuerelement mit einem UpdatePanel-Steuerelement.

  3. Speichern Sie die Seite.

Sie können die Seite jetzt noch einmal testen.

So testen Sie die Seite

  • Drücken Sie STRG+F5, um die Seite in einem Browser anzuzeigen.

    Beachten Sie, dass kein vollständiges Postback erfolgt, wenn Sie als Listenfilterung Aktiv oder Abgeschlossen wählen, und dass die aktualisierte Liste der Daten unter ListView ohne Flackern angezeigt wird.

Nächste Schritte

Diese exemplarische Vorgehensweise hat verdeutlicht, wie Sie einer Seite mit einem LinqDataSource-Steuerelement ListView hinzufügen, um das Hinzufügen, Ändern und Löschen von Aufgaben in einer Datenbank zu ermöglichen. Anschließend haben Sie mithilfe des UpdatePanel-Steuerelements die AJAX-Funktionalität hinzugefügt.

Weitere Informationen dazu, wie Sie mit Datenbanken arbeiten, finden Sie z. B. in den exemplarischen Vorgehensweisen Exemplarische Vorgehensweise: Datenbindung an ein benutzerdefiniertes Geschäftsobjekt und Exemplarische Vorgehensweise: Erstellen von Master-Detail-Webseiten in Visual Studio.

Siehe auch

Konzepte

Übersicht über das LinqDataSource-Webserversteuerelement

Übersicht über ASP.NET-AJAX

Übersicht über das Teilrendering von Seiten