Sie sind hier:
Lexikon/Glossar
Telefon (Mo-Fr 9 bis 16 Uhr):
+49 (0)201 649590-50
|
Kontaktformular
MENU
Start
Hauptseite
Angebote im Überblick
Kernkompetenzen
Softwareentwicklung
Beratung
Firmen-Schulungen
Offene Seminare
Online-Maßnahmen
Vorträge
Coaching
Support
Fachbücher
Fachartikel
Konditionen
Themen
Themenüberblick
Aktuelle Themen
Web & Cloud
Apps / Mobilplattformen
Benutzeroberflächen / User Experience
.NET
JavaScript/TypeScript
Java
Programmiersprachen/Sprachsyntax
Entwicklungswerkzeuge
Scripting
Softwareentwicklung allgemein
Datenbanken
Betriebssysteme und Virtualisierung
Microsoft Server-Produkte
Windows und Microsoft Office für Anwender
Allgemeine IT-Themen
Beratung
Beratungsthemen
Coaching
Softwareentwicklung
Technischer Support
Unsere Top-Berater
Referenzkunden
Angebotsanfrage
Individuelle Schulungen
1019 Schulungsthemen
Agendakonfigurator
Weiterbildungsphilosophie
Didaktische Konzepte
Vor-Ort oder Online
Unsere Top-Trainer
Referenzkunden
Teilnehmerfeedback
Angebotsanfrage
Offene Seminare
.NET-Akademie
.NET/C#-Basisseminar
WPF
WinUI
.NET MAUI
Blazor
ASP.NET WebAPI & gRPC
Entity Framework Core
Unit Testing / TDD
PowerShell
Infotage
Wissen
Übersicht
Fachbücher
Fachartikel
Konferenzvorträge
Konferenzen/Events
Spickzettel
Lexikon/Glossar
Programmcodebibliothek
Versionshistorie
Weblog
Downloads
Newsletter
Community-/Leserportal
Registrierung
.NET/C#/Visual Studio
.NET 8.0
.NET 7.0
.NET 6.0
ASP.NET (Core)/Blazor
PowerShell
Über uns
Kontakt
Selbstdarstellung
Kernkompetenzen
Dr. Holger Schwichtenberg
Top-Experten
Leitung & Kundenteam
Referenzkunden
Kundenaussagen
Referenzprojekte
Partner
Konditionen
Stellenangebote
Weitere Websites
Impressum
Datenschutzerklärung, Haftung, Urheberrecht
Suche
Themenkatalog
Tag Cloud
Volltextsuche
Site Map
FAQs
Erklärung des Begriffs: ASP.NET Dynamic Data Website (DDS)
Begriff
ASP.NET Dynamic Data Website
Abkürzung
DDS
Eintrag zuletzt aktualisiert am
31.12.2012
Zur Stichwortliste unseres Lexikons
Was ist
ASP.NET Dynamic Data Website
?
Dynamische Datenwebsites (Dynamic Data Sites - DDS, alias DynData) sind ein neues Konzept zum
Rapid Application Development
(
RAD
) von datengetriebener Websites in
ASP.NET
ab Version 3.5
Service Pack
1. Man erstellt mit
LINQ-to-SQL
oder dem
ADO.NET Entity Framework
ein
Objekt
modell seiner
Datenbank
. Durch Vorlagen und Konventionen entsteht dann ohne weiteres zutun des Entwicklers eine komplette Website zur Ansicht der Daten (inkl. Navigation zwischen den in Beziehung stehenden Tabellen) sowie Pflege der Daten. Anschließend kann der Entwickler dieses Grundgerüst an spezielle Bedürfnisse anpassen.
Codename: Jasper
Vorgestellt auf der
MIX
2007
erschienen 2008 mit dem
Service Pack
1 des
.NET Framework 3.5
Grundkonzept
Mit dem
Service Pack
1 des
.NET Framework 3.5
hat Microsoft einen neuen Ansatz für datengetriebene
ASP.NET
-Websites vorgestellt, der das Prinzip des
RAD
noch viel weiter treibt als das SqlDataSource-
Steuerelement
. Bisher musste der Webentwickler für jede einzelne Tabelle (oder Klasse) die Datenmaske zur Anzeige und Eingabe einzeln anlegen. Dynamische Datenwebsites (Dynamic Data Web Sites) hingegen erzeugen eine Standarddarstellung für ein
Objekt
modell, das mit Hilfe von
LINQ-to-SQL
oder dem
ADO.NET Entity Framework
auf Basis einer
Datenbank
definiert wurde. Die Datenwebsite enthält Vorlagen für Seitentypen und Spaltentypen, die dann auf allen
Datenbank
tabellen angewendet werden. Statt mehreren Seiten pro Tabelle gibt es nur wenige Vorlagen. Sonderfälle erschlägt man dann durch eigene Vorlagen.
Die durch Vorlagen generierte Oberfläche bietet die Datenanzeige inklusive Filterung, die Navigation zwischen in Beziehung stehenden
Objekt
en sowie die Änderung dieser Daten inklusive Validierung der Eingaben. Auch das Hinzufügen und Löschen von
Objekt
en ist möglich. Dazu liest
ASP.NET
zur Laufzeit das Schema des
Objekt
modells aus und verbindet es mit einer Reihe vordefinierter Seiten- und Feldvorlagen. Anpassungen der Darstellung sind aber durch
Annotation
en des Modells möglich, der Veränderung der Vorlagen bzw. der Erstellung eigener Vorlagen.
Gegenüber der SqlDataSource unterscheidet sich der Ansatz dadurch, dass der Entwickler in
Visual Studio
keine spezifischen Seiten für einzelne Klasse erzeugt, die man bei einer Änderung im Modell nur schwerlich synchronisieren kann. Vielmehr kommt eine Reihe von universellen Standardvorlagen zum Einsatz, die sich automatisch an das Modell anpassen. Microsoft spricht davon, ein Grundgerüst (engl. Scaffolding) zu erstellen, das man anpassen kann. Den Begriff "Scaffolding" kennt man schon aus
Ruby on Rails
, meint aber hier nicht die Codegenerierung zu Entwicklungszeit, sondern die dynamische Erzeugung von Webseiten zur Laufzeit auf Basis vorhandener
Metadaten
.
Anlegen einer dynamischen Datenwebsite
Für die obigen Administrationsseiten auf Basis einer dynamischen Datenwebsite muss ein Entwickler kaum etwas tun. Würde man die dynamische Datenwebsite getrennt von der eigentlichen Anwendung erstellen und betreiben, wäre sie in drei Handgriffen fertig. Es macht mehr Arbeit, eine dynamische Datenwebsite in eine bestehende Webanwendung einzubauen. Genau das soll hier aber gezeigt werden.
Eine Dynamische Datenwebsite besteht aus verschiedenen Grundelementen, die man nicht von Hand anlegen sollte und möchte. Daher ist der beste Ansatz, auf Basis der Projektvorlage "Dynamic Data Entities Website" ein neues Projekt zusätzlich anzulegen und dann aus diesem Projekt die notwendigen Elemente in das bestehende Projekt zu kopieren.
Anpassen der Ansicht durch
Annotation
en
Die einfachste Möglichkeit zur Anpassung einer Datenwebsite ist die Anreicherung des
Objekt
modells mit speziellen
Annotation
en, die Microsoft im neuen Namensraum
System.ComponentModel
.Data
Annotation
s hinterlegt hat. Beispiele für solche
Annotation
en sind:
[ScaffoldTable] zum Ausblenden von Tabellen bzw. Klassen
[DisplayFormat] zur Formatierung von Ausgaben
[DisplayColumn] zur Beschriftung des Hyperlinks bei Verknüpften Daten
[Required] zur Festlegung von Pflichtfeldern bei der Dateneingabe
[Range], [StringLength] und [RegularExpression] zur Definition der erlaubten Eingaben
Da man den generierten Programmcode für die Entitätsklassen nicht verändern sollte (beim nächsten Neugenerieren würden alle Änderungen verloren gehen), nutzt man die Möglichkeiten der partiellen Klassen, um die
Annotation
en zu platzieren. Die meisten dieser
Annotation
wirken auf
Attribut
ebene und leider kann man in
.NET 3.5
für bereits deklarierte
Attribut
e keine zusätzlichen
Annotation
en vergeben. Zu jeder Entitätsklasse ist daher als unhübsche Krücke eine weitere Klasse (genannt
Metadaten
klasse) zu implementieren, in der der Entwickler die
Attribut
e nochmals definieren und dort mit
Annotation
en versehen muss. Die
Annotation
MetadataType auf der partiellen Klasse verweist dabei auf die
Metadaten
klasse.
Namespace DownloadModel
{
//
Partielle Klasse
zur generierten Entitätsklasse
[MetadataType(typeof(DA
DownloadAngebot
MetaData))]
public partial class DA_DownloadAngebot
{
partial void OnDA_DatumEndeChanging(DateTime? Value)
{
if (value < DateTime.Now) throw new Application
Exception
("Endedatum muss in der Zukunft liegen!");
}
}
//
Metadaten
klasse zur Entitätsklasse
public partial class DA
DownloadAngebot
MetaData
{
[StringLength(10)]
public string DA_Titel;
[StringLength(20)]
public string DA_Text;
[
System.ComponentModel
.Data
Annotation
s.UIHint("Key")]
public string DA_ID;
}
//
Partielle Klasse
zur generierten Entitätsklasse
[MetadataType(typeof(DD
DownloadDatei
MetaData))]
public partial class DD_DownloadDatei
{
}
//
Metadaten
klasse zur Entitätsklasse
public partial class DD
DownloadDatei
MetaData
{
[Range(0,Double.MaxValue)]
public string DD_AnzahlDownloads;
}
}
Listing 1: Durch
Annotation
en im
Objekt
modell steuert man das Verhalten der Website
Anpassungen durch Vorlagen
Mit
Annotation
en und
Methode
n kann man nur in einem eng abgesteckten Rahmen das Verhalten der generierten Seiten beeinflussen. Wer eine individuellere Darstellung will, muss durch Vorlagen ganze Seiten oder einzelne Felder anpassen. Beim Erstellen des Projekts liegen die Standardvorlagen in den Ordnern /DynamicData/
Field
Template
s und /DynamicData/Page
Template
s. Es gibt vier Seitenvorlagen für die verschiedenen Ansichtstypen: List.aspx (Tabellendarstellung), Details.aspx (Einzelansicht mit Ändern und Löschen), Insert.aspx (Einzelansicht zum Anfügen von Daten) und ListDetails.aspx (Tabellenansicht mit Einzelansicht der gewählten Zeile darunter, mit Ändern, Anfügen und Löschen). Die Feldvorlagen sind hingegen Datentypbezogen und als
ASP.NET
User Control
s realisiert, z.B. Boolean.ascx, DateTime.ascx und Text.ascx aber auch ForeignKey.ascx. Jeweils eine Variante mit "_Edit" im Namen definiert die Darstellung bei einer Dateneingabe.
Kritik
Kritisch an diesem Ansatz ist auch die Untermischung von "oberflächlichen" Informationen in das
Objekt
modell zu sehen; eine andere Oberfläche für die gleiche Daten erfordert somit ein neues
Objekt
modell.
Leider muss man die Datenwebsite-
Annotation
en auf Klassenebene einsetzen und nicht auf Ebene der
Attribut
e, da bei generierten Klassen, die als partiell gekennzeichnet sind, man zwar
Attribut
e hinzufügen kann, nicht aber
Annotation
en zu bestehenden
Attribut
en hinzufügen kann.
Geschichte
Codename war:
Oryx
Früherer Name:
Dynamic Data Controls
Erste Erwähnug:
MIX
07 (Mai 2007)
Erscheinungstermin: Dynamic Data Websites sind im Rahmen von
.NET 3.5
Service Pack
1 im August 2008 erschienen.
Details
Namensraum:
System.Web
.DynamicData
Besondere
Steuerelement
e:
DynamicControl
DynamicDataManager
Dynamic
Validator
Dynamic
Field
u.a.
Querverweise zu anderen Begriffen im Lexikon
Rapid Application Development (RAD)
ADO.NET Entity Framework (EF)
Dynamic Data Controls (DDD)
System.ComponentModel
.NET Framework 3.5 (.NET 3.5)
Partielle Klasse
Visual Studio (VS)
Steuerelement
Ruby on Rails (Rails)
Service Pack (SP)
User Control
LINQ-to-SQL (LTS)
Annotation
System.Web
Metadaten
Validator
Exception
Datenbank (DB)
Template
.NET 3.5
Attribut
Methode
Objekt
Field
Oryx
MIX
Active Server Pages .NET (ASP.NET)
Rapid Application Development (RAD)
Beratung & Support
Anfrage für Beratung/Consulting zu ASP.NET Dynamic Data Website DDS
Gesamter Beratungsthemenkatalog
Technischer Support zum ASP.NET Dynamic Data Website DDS
Schulungen zu diesem Thema
ASP.NET Dynamic Data Websites - das "Ruby on Rails" von .NET
Java 15-Update (Neuerungen in Java 15 gegenüber Version 14)
Anfrage für eine individuelle Schulung zum Thema ASP.NET Dynamic Data Website DDS
Gesamter Schulungsthemenkatalog
Bücher zu diesem Thema
Alle unsere aktuellen Fachbücher
E-Book-Abo für ab 99 Euro im Jahr