Extensiones CSS – Prefijos de proveedores de CSS

Prefijos de proveedores de CSS – CSS Vendor Prefixes

Los prefijos de proveedores de CSS, a veces denominados prefijos de navegador CSS, se utilizan en los nombres de propiedades de CSS para implementar funciones CSS experimentales o preliminares que aún no están estandarizadas o que pueden tener soporte limitado en ciertos navegadores. Los prefijos de proveedores se utilizan para identificar navegadores específicos o versiones de navegador que admiten estas funciones.

Los principales proveedores de navegadores suelen utilizar los siguientes prefijos para implementar funciones CSS no estándar:

Según la especificación CSS, las extensiones específicas del proveedor de CSS deben comenzar con un guión o guión bajo y tener el siguiente formato:

['-' or '_'] + [vendor identifier] + ['-'] + [name]

Por ejemplo, -webkit-border-radius es una propiedad con prefijo del proveedor que le permite redondear las esquinas de los elementos para crear un diseño visualmente atractivo y moderno en navegadores basados ​​en WebKit, como Chrome.

Extensión CSS Aspose – Ejemplo de Java

El prefijo que utiliza la biblioteca Aspose.HTML se parece a -aspose- y le brinda algunas características experimentales. A continuación se muestra una lista de funciones CSS que se pueden habilitar usando el prefijo -aspose-:

NameDescription
currentPageNumberThis function returns the number of the current rendering page.
totalPagesNumberThis function returns the number of the total pages in the document.

El siguiente fragmento de código demuestra cómo usar extensiones CSS para crear marcas personalizadas en los márgenes del documento:

  1. Inicialice una instancia de la clase Configuración.
  2. Utilice el método getService() para obtener la implementación del servicio del Agente de usuario de la configuración.
  3. Utilice el método setUserStyleSheetU() para definir reglas CSS para márgenes de página, ubicación de contenido y estilo para títulos y contadores de páginas.
    • Aquí se utiliza la propiedad CSS -aspose-content para definir el contenido que se muestra en el área inferior derecha. Incluye las funciones currentPageNumber() y totalPagesNumber(), que proporciona la biblioteca Aspose.HTML para generar dinámicamente el número de página actual y un número total de páginas.
    • Además, la extensión CSS -aspose-content define el contenido que se muestra en el área superior central. Establece el contenido en la cadena “Hello, World Document Title!!!”.
  4. Inicializa un documento HTML utilizando la clase HTMLDocument.
  5. Cree una instancia de XpsDevice y especifique la ruta del archivo de salida donde se guardará el documento renderizado.
  6. Utilice el método renderTo(device) para convertir HTML a XPS.
 1//  Initialize a configuration object
 2Configuration configuration = new Configuration();
 3
 4// Get the User Agent Service
 5IUserAgentService userAgent = configuration.getService(IUserAgentService.class);
 6
 7// Set a style of custom margins and create marks on it
 8userAgent.setUserStyleSheet(
 9        "@page {\n" +
10                "  /* Page margins should be not empty in order to write content inside the margin-boxes */\n" +
11                "  margin-top: 1cm;\n" +
12                "  margin-left: 2cm;\n" +
13                "  margin-right: 2cm;\n" +
14                "  margin-bottom: 2cm;\n" +
15                "  /* Page counter located at the bottom of the page */\n" +
16                "  @bottom-right {\n" +
17                "    -aspose-content: \"Page \" currentPageNumber() \" of \" totalPagesNumber();\n" +
18                "    color: green;\n" +
19                "  }\n" +
20                "  /* Page title located at the top-center box */\n" +
21                "  @top-center {\n" +
22                "    -aspose-content: \"Hello, World Document Title!!!\";\n" +
23                "    vertical-align: bottom;\n" +
24                "    color: blue;\n" +
25                "  }\n" +
26                "}");
27//  Initialize an HTML document
28HTMLDocument document = new HTMLDocument("<div>Hello, World!!!</div>", ".", configuration);
29
30//  Initialize an output device
31XpsDevice device = new XpsDevice("output.xps");
32
33// Send the document to the output device
34document.renderTo(device);

Recomendaciones

Puede descargar los ejemplos completos y los archivos de datos desde GitHub.

Subscribe to Aspose Product Updates

Get monthly newsletters & offers directly delivered to your mailbox.