[Xamarin.Forms] Ahora podemos usar contenido Html en Labels

Introducción

Uno de los controles habituales en cualquier aplicación Xamarin.Forms es el control Label. Al fin y al cabo, necesitamos mostrar texto de diversas formas. Es por eso, que es uno de los controles que recibe mejoras de forma constante. Recientemente hemos recibido espaciado entre carácteres, padding y soporte a contenido HTML.

Html como contenido

Antes que nada, HTML es potente y permite una cantidad de contenido diverso. No, no vas a poder añadir un video de YouTube como contenido. Se soportan etiquetas básicas como negritas, cabeceras, etc.

¿Cómo utilizar HTML como contenido?

Se ha añadido la propiedad TextType al Label. Con esta propiedad podemos indicar si queremos renderizar el texto directamente, Text, o como HTML.

Label htmlLabel = new Label() { TextType = TextType.Html };

De modo que, para establecer el contenido seguimos utilizando la propiedad Text:

htmlLabel.Text = "<h1>Hello World!</h1><br/>SecondLine";

Desde XAML, para utilizar HTML como contenido tenemos dos opciones:

  • Codificar la cadena HTML.
  • Usar CDATA.

Codificar la cadena, aunque es una opción, requiere trabajo extra:

<Label TextType="Html">
    <Label.Text>
        &lt;h1&gt;Hello World!&lt;/h1&gt;&lt;br/&gt;SecondLine
    </Label.Text>
</Label>

Usando CDATA:

<Label TextType="Html">
     <Label.Text>
          <x:String>
          <![CDATA[
          <h1>Hello world!</h1><br/>SecondLine
          ]]>
          </x:String>
     </Label.Text>
</Label>

El resultado:

Label con contenido HTML

¿Qué te parece esta nueva opción?. Recuerda, puedes dejar cualquier feedback o comentario en la entrada!.

Más información

Anuncios

2 pensamientos en “[Xamarin.Forms] Ahora podemos usar contenido Html en Labels

  1. Gracias por tu blog: es de lo más útil para mantenerse al día (imprescindible en algo tan cambiante como Xamarin)

    Una pequeña corrección:

    Falta el TextType=”Html” en la etiqueta del ejemplo Usando CDATA.

    Saludos.

Responder

Introduce tus datos o haz clic en un icono para iniciar sesión:

Logo de WordPress.com

Estás comentando usando tu cuenta de WordPress.com. Cerrar sesión /  Cambiar )

Google photo

Estás comentando usando tu cuenta de Google. Cerrar sesión /  Cambiar )

Imagen de Twitter

Estás comentando usando tu cuenta de Twitter. Cerrar sesión /  Cambiar )

Foto de Facebook

Estás comentando usando tu cuenta de Facebook. Cerrar sesión /  Cambiar )

Conectando a %s