Exportar (0) Imprimir
Expandir todo
Este artículo proviene de un motor de traducción automática. Mueva el puntero sobre las frases del artículo para ver el texto original. Más información.
Traducción
Original

GenerateScriptTypeAttribute (Clase)

Especifica que el tipo de servidor se debe generar en el objeto proxy. Esta clase no puede heredarse.

System.Object
  System.Attribute
    System.Web.Script.Services.GenerateScriptTypeAttribute

Espacio de nombres:  System.Web.Script.Services
Ensamblado:  System.Web.Extensions (en System.Web.Extensions.dll)

[AttributeUsageAttribute(AttributeTargets.Class|AttributeTargets.Method|AttributeTargets.Interface, AllowMultiple = true)]
public sealed class GenerateScriptTypeAttribute : Attribute

El tipo GenerateScriptTypeAttribute expone los siguientes miembros.

  NombreDescripción
Método públicoGenerateScriptTypeAttributeInicializa una nueva instancia de la clase GenerateScriptTypeAttribute para el tipo especificado.
Arriba

  NombreDescripción
Propiedad públicaScriptTypeIdObtiene o establece el identificador de tipo para el marcador de metadatos de tipo.
Propiedad públicaTypeObtiene el tipo que está incluido en el objeto proxy.
Propiedad públicaTypeIdCuando se implementa en una clase derivada, obtiene un identificador único para este Attribute. (Se hereda de Attribute).
Arriba

  NombreDescripción
Método públicoEqualsInfraestructura. Devuelve un valor que indica si esta instancia equivale al objeto especificado. (Se hereda de Attribute).
Método públicoGetHashCodeDevuelve el código hash de esta instancia. (Se hereda de Attribute).
Método públicoGetType Obtiene el Type de la instancia actual. (Se hereda de Object).
Método públicoIsDefaultAttributeCuando se invalida en una clase derivada, indica si el valor de esta instancia es el valor predeterminado para la clase derivada. (Se hereda de Attribute).
Método públicoMatch Cuando se invalida en una clase derivada, devuelve un valor que indica si esta instancia es igual al objeto especificado. (Se hereda de Attribute).
Método públicoToString Retorna una cadena que representa al objeto actual. (Se hereda de Object).
Arriba

  NombreDescripción
Implementación explícita de interfacesMétodo privado_Attribute.GetIDsOfNamesAsigna un conjunto de nombres a un conjunto correspondiente de identificadores de envío. (Se hereda de Attribute).
Implementación explícita de interfacesMétodo privado_Attribute.GetTypeInfoObtiene la información de tipos de un objeto, que puede utilizarse para obtener la información de tipos de una interfaz. (Se hereda de Attribute).
Implementación explícita de interfacesMétodo privado_Attribute.GetTypeInfoCount

Recupera el número de interfaces de tipo de información que suministra un objeto (0 ó 1)

(Se hereda de Attribute).
Implementación explícita de interfacesMétodo privado_Attribute.InvokeProporciona acceso a las propiedades y los métodos expuestos por un objeto. (Se hereda de Attribute).
Arriba

En sitios web de ASP.NET habilitados para AJAX, ASP.NET puede generar automáticamente objetos proxy para los métodos de una clase de servicio Web. Lo hace para la mayoría de los tipos de nivel superior de los parámetros de entrada y valores devueltos de cualquier método web que se marca con ScriptServiceAttribute.

En otros casos, si tiene objetos proxy generados para los tipos de servidor, debe aplicar manualmente GenerateScriptTypeAttribute. Puede aplicar GenerateScriptTypeAttribute al propio servicio Web o a cualquier método de servicio Web o método de página static que se haya marcado con WebMethodAttribute.

En algunos casos, aun cuando el tipo corresponde a un parámetro de entrada o valor devuelto de un método de servicio Web, no se generará el proxy automáticamente. En ese caso, debe utilizar el atributo GenerateScriptTypeAttribute para generar el objeto proxy para el tipo. Esto sucede para los tipos genéricos y las matrices que tienen más de un argumento, como Dictionary<string,<T>>.

Es posible aplicar una o más instancias de GenerateScriptTypeAttribute a una clase o método de servicio Web. ASP.NET generará después una clase de proxy ECMAScript (JavaScript) para cada tipo de nivel superior al que se haga referencia en cada declaración de GenerateScriptTypeAttribute.

NotaNota

Si desea generar objetos proxy para los tipos anidados, debe aplicar manualmente GenerateScriptTypeAttribute a cada tipo anidado. ASP.NET genera proxies sólo para los tipos de nivel superior y no aplica automáticamente y de forma recursiva el atributo a los tipos anidados.

Para obtener más información acerca de cómo utilizar los atributos, vea Extender metadatos mediante atributos.

El ejemplo siguiente muestra cómo aplicar GenerateScriptTypeAttribute a una clase de servicio Web y a un método web. Como resultado, el tipo ColorObject y su tipo anidado FavoriteColors se incluyen en el objeto proxy.


<%@ WebService Language="C#" Class="Samples.AspNet.ColorService" %>

using System;
using System.Web;
using System.Web.Services;
using System.Web.Services.Protocols;
using System.Web.Script.Services;

namespace Samples.AspNet
{

    [WebService(Namespace = "http://tempuri.org/")]
    [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
    [ScriptService]
    [GenerateScriptType(typeof(FavoriteColors))]
    public class ColorService : System.Web.Services.WebService
    {

        [GenerateScriptType(typeof(ColorObject), 
            ScriptTypeId = "Color")]
        [WebMethod]
        public string[] GetDefaultColor()
        {
            // Instantiate the default color object.
            ColorObject co = new ColorObject();

            return co.rgb;
        }

        [WebMethod]
        public string EchoDefaultColor()
        {
            // Instantiate the default color object.
            ColorObject co = new ColorObject();

            return co.defaultColor.ToString();
        }
    }

    public class ColorObject
    {
        public string[] rgb =
            new string[] { "00", "00", "FF" };
        public FavoriteColors defaultColor = FavoriteColors.Blue;
    }

    public enum FavoriteColors
    {
        Black,
        White,
        Blue,
        Red
    }
}


.NET Framework

Compatible con: 4.5.2, 4.5.1, 4.5, 4, 3.5

Windows Phone 8.1, Windows Phone 8, Windows 8.1, Windows Server 2012 R2, Windows 8, Windows Server 2012, Windows 7, Windows Vista SP2, Windows Server 2008 (no se admite el rol Server Core), Windows Server 2008 R2 (se admite el rol Server Core con SP1 o versiones posteriores; no se admite Itanium)

.NET Framework no admite todas las versiones de todas las plataformas. Para obtener una lista de las versiones compatibles, vea Requisitos de sistema de .NET Framework.

Todos los miembros static (Shared en Visual Basic) públicos de este tipo son seguros para la ejecución de subprocesos. No se garantiza que los miembros de instancias sean seguros para la ejecución de subprocesos.

Adiciones de comunidad

AGREGAR
Mostrar:
© 2014 Microsoft