Sdílet prostřednictvím


DataTypeAttribute Třída

Definice

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 zobrazují jako hypertextové odkazy místo jako jednoduchý text, který by dynamická data odvodila 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 značí šabloně 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

Ke kompilaci a spuštění ukázkového kódu potřebujete následující:

  • Libovolná edice sady 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 Ukázky produktů Microsoft SQL Server: Databáze na GitHubu. 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 vám umožní vytvořit kontext dat pro databázi a vytvořit třídu, která obsahuje datové pole, které chcete přizpůsobit. Další informace naleznete v tématu 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 vybraný z typu výčtu DataType . Jako typ lze například zadat EmailAddress datové pole řetězce, které obsahuje e-mailové adresy. K této informaci pak přistupují šablony polí, aby se změnil způsob zpracování datového pole.

Atribut používáte DataTypeAttribute z následujících důvodů:

  • Chcete-li zadat 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 a určit způsob zpracování pole. Šablona textového pole může například generovat hypertextové odkazy pro e-mailové adresy, jejichž vnitřní typ je String.

  • Chcete-li přidružit šablonu 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 .

Při použití atributu DataTypeAttribute u datového pole je nutné provést následující kroky:

  • 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í.

Další informace najdete v tématu ASP.NET pokyny k dynamickým datům.

Konstruktory

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

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 ověření selže.

(Zděděno od ValidationAttribute)
ErrorMessageResourceName

Získá nebo nastaví název prostředku chybové zprávy, aby bylo možné vyhledat ErrorMessageResourceType hodnotu 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 tuto Attributetřídu .

(Zděděno od Attribute)

Metody

Equals(Object)

Vrací hodnotu, která určuje, zda je tato instance rovna zadanému objektu.

(Zděděno od Attribute)
FormatErrorMessage(String)

Použije formátování chybové zprávy 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í hodnotu hash pro tuto instanci.

(Zděděno od Attribute)
GetType()

Získá aktuální Type instanci.

(Zděděno od Object)
GetValidationResult(Object, ValidationContext)

Zkontroluje, jestli je zadaná hodnota platná vzhledem k aktuálnímu ověřovacímu atributu.

(Zděděno od ValidationAttribute)
IsDefaultAttribute()

Při přepsání v odvozené třídě označuje, zda je hodnota této instance výchozí hodnotou pro odvozenou třídu.

(Zděděno od Attribute)
IsValid(Object)

Zkontroluje, jestli je hodnota datového pole platná.

IsValid(Object, ValidationContext)

Ověří zadanou hodnotu vzhledem k aktuálnímu ověřovacímu atributu.

(Zděděno od ValidationAttribute)
Match(Object)

Při přepsání v odvozené třídě vrátí hodnotu, která označuje, zda se tato instance rovná zadanému objektu.

(Zděděno od Attribute)
MemberwiseClone()

Vytvoří mělkou kopii aktuálního Objectsouboru .

(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í

_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)

Platí pro

Viz také