AttributeTargets Enumeration
Specifies the application elements on which it is valid to apply an attribute.
This enumeration has a FlagsAttribute attribute that allows a bitwise combination of its member values.
Namespace: SystemAssembly: mscorlib (in mscorlib.dll)
| Member name | Description | |
|---|---|---|
![]() ![]() | Assembly | Attribute can be applied to an assembly. |
![]() ![]() | Module | Attribute can be applied to a module. NoteModule refers to a portable executable file (.dll or.exe) and not a Visual Basic standard module. |
![]() ![]() | Class | Attribute can be applied to a class. |
![]() ![]() | Struct | Attribute can be applied to a structure; that is, a value type. |
![]() ![]() | Enum | Attribute can be applied to an enumeration. |
![]() ![]() | Constructor | Attribute can be applied to a constructor. |
![]() ![]() | Method | Attribute can be applied to a method. |
![]() ![]() | Property | Attribute can be applied to a property. |
![]() ![]() | Field | Attribute can be applied to a field. |
![]() ![]() | Event | Attribute can be applied to an event. |
![]() ![]() | Interface | Attribute can be applied to an interface. |
![]() ![]() | Parameter | Attribute can be applied to a parameter. |
![]() ![]() | Delegate | Attribute can be applied to a delegate. |
![]() ![]() | ReturnValue | Attribute can be applied to a return value. |
![]() ![]() | GenericParameter | Attribute can be applied to a generic parameter. NoteCurrently, this attribute can be applied only in C#, Microsoft intermediate language (MSIL), and emitted code. |
![]() ![]() | All | Attribute can be applied to any application element. |
The AttributeUsageAttribute class uses this enumeration to specify the kind of element on which it is valid to apply an attribute.
AttributeTargets enumeration values can be combined with a bitwise OR operation to get the preferred combination.
The following example illustrates the application of attributes to various targets.
Note |
|---|
Visual Basic and Visual C++ syntax currently do not support the application of attributes to type parameters. |
using namespace System; namespace AttTargsCS { // This attribute is only valid on a class. [AttributeUsage(AttributeTargets::Class)] public ref class ClassTargetAttribute: public Attribute{}; // This attribute is only valid on a method. [AttributeUsage(AttributeTargets::Method)] public ref class MethodTargetAttribute: public Attribute{}; // This attribute is only valid on a constructor. [AttributeUsage(AttributeTargets::Constructor)] public ref class ConstructorTargetAttribute: public Attribute{}; // This attribute is only valid on a field. [AttributeUsage(AttributeTargets::Field)] public ref class FieldTargetAttribute: public Attribute{}; // This attribute is valid on a class or a method. [AttributeUsage(AttributeTargets::Class|AttributeTargets::Method)] public ref class ClassMethodTargetAttribute: public Attribute{}; // This attribute is valid on any target. [AttributeUsage(AttributeTargets::All)] public ref class AllTargetsAttribute: public Attribute{}; [ClassTarget] [ClassMethodTarget] [AllTargets] public ref class TestClassAttribute { private: [ConstructorTarget] [AllTargets] TestClassAttribute(){} public: [MethodTarget] [ClassMethodTarget] [AllTargets] void Method1(){} [FieldTarget] [AllTargets] int myInt; static void Main(){} }; }
Windows 7, Windows Vista SP1 or later, Windows XP SP3, Windows XP SP2 x64 Edition, Windows Server 2008 (Server Core not supported), Windows Server 2008 R2 (Server Core supported with SP1 or later), Windows Server 2003 SP2
The .NET Framework does not support all versions of every platform. For a list of the supported versions, see .NET Framework System Requirements.


Note