Preferences
Examinar ejemplo. Examinar el ejemplo
En este artículo se describe cómo puedes usar la interfaz IPreferences
de .NET Multi-platform App UI (.NET MAUI). Esta interfaz ayuda a almacenar las preferencias de la aplicación en un almacén de clave y valor.
La implementación predeterminada de la interfaz IPreferences
está disponible a través de la propiedad Preferences.Default
. Tanto la interfaz IPreferences
como la clase Preferences
están contenidas en el espacio de nombres Microsoft.Maui.Storage
.
Tipos de almacenamiento
Preferences se almacenan con una clave String. El valor de una preferencia debe ser uno de los siguientes tipos de datos:
Los valores de DateTime
se almacenan en un formato binario de 64 bits (entero largo) mediante dos métodos definidos por la clase DateTime
:
- El método
ToBinary
se usa para codificar el valorDateTime
. - El método
FromBinary
descodifica el valor.
Consulta la documentación de estos métodos para obtener los ajustes que se podrían realizar en los valores descodificados cuando se almacena un valor DateTime
que no es de hora universal coordinada (UTC).
Establecer preferencias
Preferences se establecen llamando al método Preferences.Set
, proporcionando la clave y el valor:
// Set a string value:
Preferences.Default.Set("first_name", "John");
// Set an numerical value:
Preferences.Default.Set("age", 28);
// Set a boolean value:
Preferences.Default.Set("has_pets", true);
Obtener preferencias
Para recuperar un valor de las preferencias, pase la clave de la preferencia, seguida del valor predeterminado cuando la clave no exista:
string firstName = Preferences.Default.Get("first_name", "Unknown");
int age = Preferences.Default.Get("age", -1);
bool hasPets = Preferences.Default.Get("has_pets", false);
En algunos casos, es posible que tengas que pasar la clave de la preferencia, seguida del valor predeterminado y su tipo:
long value = Preferences.Get("master_date", (long)0);
Comprobar una clave
Puede ser útil comprobar si existe una clave en las preferencias o no. Aunque Get
haya establecido un valor predeterminado cuando la clave no existe, puede haber casos en los que existía la clave, pero el valor de la clave coincidía con el valor predeterminado. Por lo tanto, no puedes confiar en el valor predeterminado como un indicador de que la clave no existe. Usa el método ContainsKey
para determinar si una clave existe:
bool hasKey = Preferences.Default.ContainsKey("my_key");
Eliminación de una o todas las claves
Use el método Remove
para quitar una clave específica de las preferencias:
Preferences.Default.Remove("first_name");
Para quitar todas las claves, usa el método Clear
:
Preferences.Default.Clear();
Claves compartidas
Las preferencias almacenadas por la aplicación solo son visibles para la aplicación. Pero también puedes crear una preferencia compartida que pueden usar otras extensiones o una aplicación de inspección. Al establecer, quitar o recuperar una preferencia, se puede proporcionar un parámetro de cadena opcional para especificar el nombre del contenedor en el que se almacena la preferencia.
Los métodos siguientes toman un parámetro de cadena denominado sharedName
:
Preferences.Set
Preferences.Get
Preferences.Remove
Preferences.Clear
Importante
Lea los detalles de implementación de la plataforma, ya que las preferencias compartidas tienen implementaciones específicas del comportamiento.
Integración con la configuración del sistema
Preferences se almacenan de forma nativa, lo que permite integrar la configuración en la configuración nativa del sistema. Siga la documentación de la plataforma para integrar con la plataforma:
- Apple: Implementación de un lote de configuración de iOS
- Android: Introducción a las pantallas de configuración
Diferencias entre plataformas
En esta sección se describen las diferencias específicas de la plataforma con la API de preferencias.
Todos los datos se almacenan en preferencias compartidasPreferences. Si no se especifica ninguna sharedName
, se usarán las compartidasPreferences predeterminadas. De lo contrario, el nombre se usa para obtener Preferences compartidas privadas con el nombre especificado.
Persistencia
La desinstalación de la aplicación hace que se quiten todas las preferencias de
Limitaciones
El rendimiento puede verse afectado si se almacena grandes cantidades de texto, ya que la API se diseñó para almacenar pequeñas cantidades de texto.