DataTypeAttribute Třída
Definice
Důležité
Některé informace platí pro předběžně vydaný produkt, který se může zásadně změnit, než ho výrobce nebo autor vydá. Microsoft neposkytuje žádné záruky, výslovné ani předpokládané, týkající se zde uváděných informací.
Určuje název dalšího typu, který se má přidružit k datovému poli.
public ref class DataTypeAttribute : System::ComponentModel::DataAnnotations::ValidationAttribute
[System.AttributeUsage(System.AttributeTargets.Field | System.AttributeTargets.Method | System.AttributeTargets.Parameter | System.AttributeTargets.Property, AllowMultiple=false)]
public class DataTypeAttribute : System.ComponentModel.DataAnnotations.ValidationAttribute
[System.AttributeUsage(System.AttributeTargets.Field | System.AttributeTargets.Property, AllowMultiple=false)]
public class DataTypeAttribute : System.ComponentModel.DataAnnotations.ValidationAttribute
[<System.AttributeUsage(System.AttributeTargets.Field | System.AttributeTargets.Method | System.AttributeTargets.Parameter | System.AttributeTargets.Property, AllowMultiple=false)>]
type DataTypeAttribute = class
inherit ValidationAttribute
[<System.AttributeUsage(System.AttributeTargets.Field | System.AttributeTargets.Property, AllowMultiple=false)>]
type DataTypeAttribute = class
inherit ValidationAttribute
Public Class DataTypeAttribute
Inherits ValidationAttribute
- Dědičnost
- Odvozené
- Atributy
Příklady
Následující příklad používá DataTypeAttribute atribut k přizpůsobení zobrazení datového pole EmailAddress. E-mailové adresy se místo jednoduchého textu zobrazují jako hypertextové odkazy, což je to, co dynamická data odvodí z vnitřního datového typu. Ukázkový kód je ve třech částech a provádí následující kroky:
Implementuje částečnou třídu metadat a přidruženou třídu metadat.
Ve třídě přidružených metadat použije DataTypeAttribute atribut na datové pole EmailAddress zadáním EmailAddress výčtové hodnoty. To označuje šablonu pole Text.ascx, že by měla přizpůsobit zobrazení e-mailových adres.
Upraví šablonu pole Text.ascx tak, aby přizpůsobila zobrazení datových polí EmailAddress.
using System;
using System.Web.DynamicData;
using System.ComponentModel.DataAnnotations;
[MetadataType(typeof(CustomerMetaData))]
public partial class Customer
{
}
public class CustomerMetaData
{
// Add type information.
[DataType(DataType.EmailAddress)]
public object EmailAddress;
}
Imports System.Web.DynamicData
Imports System.ComponentModel.DataAnnotations
<MetadataType(GetType(CustomerMetadata))> _
Partial Public Class Customer
End Class
Public Class CustomerMetadata
' Add type information.
<DataType(DataType.EmailAddress)> _
Public EmailAddress As Object
End Class
<%@ Control Language="C#"
CodeFile="Text.ascx.cs" Inherits="TextField" %>
<!-- Removed, evaluated in the code behind.
<%# FieldValueString %> -->
<%@ Control Language="VB"
CodeFile="Text.ascx.vb" Inherits="TextField" %>
<!-- Removed, evaluated in the code behind.
<%# FieldValueString %> -->
using System;
using System.Linq;
using System.Web.UI.WebControls;
using System.Web.DynamicData;
using System.ComponentModel.DataAnnotations;
public partial class TextField :
System.Web.DynamicData.FieldTemplateUserControl {
protected override void OnDataBinding(EventArgs e)
{
base.OnDataBinding(e);
bool processed = false;
var metadata = MetadataAttributes.OfType
<DataTypeAttribute>().FirstOrDefault();
if (metadata != null)
{
if (metadata.DataType == DataType.EmailAddress)
{
if (!string.IsNullOrEmpty(FieldValueString))
{
processed = true;
HyperLink hyperlink = new HyperLink();
hyperlink.Text = FieldValueString;
hyperlink.NavigateUrl = "mailto:" + FieldValueString;
Controls.Add(hyperlink);
}
}
}
if (!processed)
{
Literal literal = new Literal();
literal.Text = FieldValueString;
Controls.Add(literal);
}
}
}
Imports System.Linq
Imports System.Web.UI.WebControls
Imports System.Web.DynamicData
Imports System.ComponentModel.DataAnnotations
Partial Public Class TextField
Inherits System.Web.DynamicData.FieldTemplateUserControl
Protected Overloads Overrides Sub OnDataBinding(ByVal e As EventArgs)
MyBase.OnDataBinding(e)
Dim processed As Boolean = False
Dim metadata As DataTypeAttribute = _
MetadataAttributes.OfType(Of DataTypeAttribute)().FirstOrDefault()
If metadata IsNot Nothing Then
If metadata.DataType = DataType.EmailAddress Then
If Not String.IsNullOrEmpty(FieldValueString) Then
processed = True
Dim hyperlink As New HyperLink()
hyperlink.Text = FieldValueString
hyperlink.NavigateUrl = "mailto:" + FieldValueString
Controls.Add(hyperlink)
End If
End If
End If
If Not processed Then
Dim literal As New Literal()
literal.Text = FieldValueString
Controls.Add(literal)
End If
End Sub
End Class
K kompilaci a spuštění ukázkového kódu potřebujete následující:
Libovolná edice Visual Studio 2010 nebo novější.
Ukázková databáze AdventureWorksLT. Informace o tom, jak stáhnout a nainstalovat ukázkovou databázi SQL Server, najdete v tématu Microsoft SQL Server Ukázky produktů: Databáze na GitHub. Ujistěte se, že jste nainstalovali správnou verzi ukázkové databáze pro verzi SQL Server, kterou používáte.
Web řízený daty To umožňuje vytvořit kontext dat pro databázi a vytvořit třídu, která obsahuje datové pole pro přizpůsobení. Další informace najdete na webu
Walkthrough: Creating a New Dynamic Data Web Site using Scaffolding.
Poznámky
Atribut DataTypeAttribute umožňuje označit pole pomocí typu, který je konkrétnější než vnitřní typ databáze. Název typu je vybrán z typu výčtu DataType . Jako typ lze například zadat EmailAddress datové pole řetězce, které obsahuje e-mailové adresy. Tyto informace pak šablony polí přistupují k úpravě způsobu zpracování datového pole.
Atribut použijete DataTypeAttribute z následujících důvodů:
Chcete-li poskytnout další informace o typu pro datové pole. Provedete to použitím atributu DataTypeAttribute na datové pole v datovém modelu a zadáním dalšího názvu typu z výčtu DataType . Šablona pole, která zpracovává datové pole, má přístup k tomuto dalšímu typu metadat, aby určila, jak pole zpracovat. Například šablona textového pole může generovat hypertextové odkazy pro e-mailové adresy, jejichž vnitřní typ je
String.Přidružení šablony vlastního pole k datovému poli Zadaná šablona vlastního pole se pak použije ke zpracování datového pole. Toto je alternativa k použití atributu UIHintAttribute .
Když atribut použijete DataTypeAttribute u datového pole, musíte udělat toto:
Postupujte podle pravidel použití atributů.
Implementujte třídu metadat, která obsahuje datová pole, na která chcete atribut použít.
Podle potřeby vyřešte chyby ověření.
Konstruktory
| Name | Description |
|---|---|
| DataTypeAttribute(DataType) |
Inicializuje novou instanci DataTypeAttribute třídy pomocí zadaného názvu typu. |
| DataTypeAttribute(String) |
Inicializuje novou instanci DataTypeAttribute třídy pomocí zadaného názvu šablony pole. |
Vlastnosti
| Name | Description |
|---|---|
| CustomDataType |
Získá název vlastní šablony pole, která je přidružena k datovému poli. |
| DataType |
Získá typ, který je přidružen k datovému poli. |
| DisplayFormat |
Získá formát zobrazení datového pole. |
| ErrorMessage |
Získá nebo nastaví chybovou zprávu, která se přidruží k ověřovacímu ovládacímu prvku, pokud se ověření nezdaří. (Zděděno od ValidationAttribute) |
| ErrorMessageResourceName |
Získá nebo nastaví název prostředku chybové zprávy použít k vyhledání ErrorMessageResourceType hodnoty vlastnosti v případě selhání ověření. (Zděděno od ValidationAttribute) |
| ErrorMessageResourceType |
Získá nebo nastaví typ prostředku, který se má použít pro vyhledávání chybových zpráv, pokud se ověření nezdaří. (Zděděno od ValidationAttribute) |
| ErrorMessageString |
Získá lokalizovanou ověřovací chybovou zprávu. (Zděděno od ValidationAttribute) |
| RequiresValidationContext |
Získá hodnotu, která označuje, zda atribut vyžaduje kontext ověření. (Zděděno od ValidationAttribute) |
| TypeId |
Při implementaci v odvozené třídě získá jedinečný identifikátor pro tento Attribute. (Zděděno od Attribute) |
Metody
| Name | Description |
|---|---|
| Equals(Object) |
Vrátí hodnotu, která určuje, zda je tato instance rovna zadanému objektu. (Zděděno od Attribute) |
| FormatErrorMessage(String) |
Použije formátování na chybovou zprávu na základě datového pole, ve kterém došlo k chybě. (Zděděno od ValidationAttribute) |
| GetDataTypeName() |
Vrátí název typu přidruženého k datovému poli. |
| GetHashCode() |
Vrátí kód hash pro tuto instanci. (Zděděno od Attribute) |
| GetType() |
Získá Type aktuální instance. (Zděděno od Object) |
| GetValidationResult(Object, ValidationContext) |
Zkontroluje, zda je zadaná hodnota platná s ohledem na aktuální ověřovací atribut. (Zděděno od ValidationAttribute) |
| IsDefaultAttribute() |
Při přepsání v odvozené třídě určuje, zda hodnota této instance je výchozí hodnotou pro odvozenou třídu. (Zděděno od Attribute) |
| IsValid(Object, ValidationContext) |
Ověří zadanou hodnotu s ohledem na aktuální ověřovací atribut. (Zděděno od ValidationAttribute) |
| IsValid(Object) |
Zkontroluje, jestli je hodnota datového pole platná. |
| Match(Object) |
Při přepsání v odvozené třídě vrátí hodnotu, která určuje, zda se tato instance rovná zadanému objektu. (Zděděno od Attribute) |
| MemberwiseClone() |
Vytvoří mělkou kopii aktuálního Object. (Zděděno od Object) |
| ToString() |
Vrátí řetězec, který představuje aktuální objekt. (Zděděno od Object) |
| Validate(Object, String) |
Ověří zadaný objekt. (Zděděno od ValidationAttribute) |
| Validate(Object, ValidationContext) |
Ověří zadaný objekt. (Zděděno od ValidationAttribute) |
Explicitní implementace rozhraní
| Name | Description |
|---|---|
| _Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr) |
Mapuje sadu názvů na odpovídající sadu identifikátorů pro rozesílání. (Zděděno od Attribute) |
| _Attribute.GetTypeInfo(UInt32, UInt32, IntPtr) |
Načte informace o typu objektu, který lze použít k získání informací o typu pro rozhraní. (Zděděno od Attribute) |
| _Attribute.GetTypeInfoCount(UInt32) |
Získá počet rozhraní typu informací, které objekt poskytuje (0 nebo 1). (Zděděno od Attribute) |
| _Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr) |
Poskytuje přístup k vlastnostem a metodám vystaveným objektem. (Zděděno od Attribute) |