chrome.storage

Descripción

Usa la API de chrome.storage para almacenar, recuperar y hacer un seguimiento de los cambios en los datos del usuario.

Permisos

storage

Para usar la API de Storage, declara el permiso "storage" en el manifiesto de la extensión. Por ejemplo:

{
  "name": "My extension",
  ...
  "permissions": [
    "storage"
  ],
  ...
}

Ejemplos

En los siguientes ejemplos, se muestran las áreas de almacenamiento local, sync y session:

Ejemplo (local)

chrome.storage.local.set({ key: value }).then(() => {
  console.log("Value is set");
});

chrome.storage.local.get(["key"]).then((result) => {
  console.log("Value is " + result.key);
});

Ejemplo (sincronización)

chrome.storage.sync.set({ key: value }).then(() => {
  console.log("Value is set");
});

chrome.storage.sync.get(["key"]).then((result) => {
  console.log("Value is " + result.key);
});

Ejemplo (sesión)

chrome.storage.session.set({ key: value }).then(() => {
  console.log("Value is set");
});

chrome.storage.session.get(["key"]).then((result) => {
  console.log("Value is " + result.key);
});

Para ver otras demostraciones de la API de Storage, explora cualquiera de los siguientes ejemplos:

Conceptos y uso

La API de Storage proporciona una forma específica de la extensión para conservar los datos y el estado del usuario. Es similar a las APIs de almacenamiento de la plataforma web (IndexedDB y Storage), pero se diseñó para satisfacer las necesidades de almacenamiento de las extensiones. Estas son algunas de sus funciones clave:

  • Todos los contextos de extensión, incluidos el trabajador de servicio de la extensión y las secuencias de comandos de contenido, tienen acceso a la API de Storage.
  • Los valores serializables en JSON se almacenan como propiedades de objetos.
  • La API de Storage es asíncrona y admite operaciones de lectura y escritura masivas.
  • Los datos persisten incluso si el usuario borra la caché y el historial de navegación.
  • Los parámetros de configuración almacenados persisten incluso cuando se usa el modo Incógnito dividido.
  • Incluye un área de almacenamiento administrada exclusiva de solo lectura para las políticas empresariales.

¿Pueden las extensiones usar las APIs de almacenamiento web?

Si bien las extensiones pueden usar la interfaz Storage (accesible desde window.localStorage) en algunos contextos (páginas emergentes y otras páginas HTML), no la recomendamos por los siguientes motivos:

  • Los service workers de extensiones no pueden usar la API de Web Storage.
  • Las secuencias de comandos de contenido comparten almacenamiento con la página host.
  • Los datos guardados con la API de Web Storage se pierden cuando el usuario borra su historial de navegación.

Para mover datos de las APIs de almacenamiento web a las APIs de almacenamiento de extensiones desde un service worker, haz lo siguiente:

  1. Prepara una página HTML y un archivo de secuencia de comandos para el documento fuera de pantalla. El archivo de secuencia de comandos debe contener una rutina de conversión y un controlador onMessage.
  2. En el service worker de la extensión, verifica chrome.storage para ver tus datos.
  3. Si no se encuentran tus datos, llama a createDocument().
  4. Después de que se resuelva la promesa devuelta, llama a sendMessage() para iniciar la rutina de conversión.
  5. Dentro del controlador onMessage del documento fuera de pantalla, llama a la rutina de conversión.

También hay algunos matices sobre cómo funcionan las APIs de almacenamiento web en las extensiones. Obtén más información en el artículo Almacenamiento y cookies.

Límites de almacenamiento y regulación

La API de Storage tiene limitaciones de uso:

  • El almacenamiento de datos tiene costos de rendimiento, y la API incluye cuotas de almacenamiento. Planifica los datos que deseas almacenar para mantener espacio de almacenamiento.
  • El almacenamiento puede tardar en completarse. Estructura tu código para tener en cuenta ese tiempo.

Para obtener detalles sobre las limitaciones del área de almacenamiento y lo que sucede cuando se superan, consulta la información de cuotas de sync, local y session.

Áreas de almacenamiento

La API de Storage se divide en las siguientes áreas de almacenamiento:

Local

Los datos se almacenan de forma local y se borran cuando se quita la extensión. El límite de almacenamiento es de 10 MB (5 MB en Chrome 113 y versiones anteriores), pero se puede aumentar solicitando el permiso "unlimitedStorage". Recomendamos usar storage.local para almacenar mayores cantidades de datos. De forma predeterminada, se expone a las secuencias de comandos de contenido, pero este comportamiento se puede cambiar llamando a chrome.storage.local.setAccessLevel().

Administrado

El almacenamiento administrado es de solo lectura para las extensiones instaladas por políticas. Los administradores del sistema lo administran con un esquema definido por el desarrollador y políticas empresariales. Las políticas son similares a las opciones, pero las configura un administrador del sistema, en lugar del usuario. Esto permite que la extensión se preconfigure para todos los usuarios de una organización.

De forma predeterminada, storage.managed se expone a las secuencias de comandos de contenido, pero este comportamiento se puede cambiar llamando a chrome.storage.managed.setAccessLevel(). Para obtener información sobre las políticas, consulta la Documentación para administradores. Para obtener más información sobre el área de almacenamiento managed, consulta Manifiesto para áreas de almacenamiento.

Sesión

El almacenamiento de sesión mantiene los datos en la memoria mientras se carga una extensión. El almacenamiento se borra si la extensión se inhabilita, se vuelve a cargar, se actualiza y cuando se reinicia el navegador. De forma predeterminada, no se expone a las secuencias de comandos de contenido, pero este comportamiento se puede cambiar llamando a chrome.storage.session.setAccessLevel(). El límite de almacenamiento es de 10 MB (1 MB en Chrome 111 y versiones anteriores).

La interfazstorage.session es una de las varias que recomendamos para los service workers.

Sincronizar

Si el usuario habilita la sincronización, los datos se sincronizarán con todos los navegadores Chrome a los que haya accedido. Si está inhabilitado, se comporta como storage.local. Chrome almacena los datos de forma local cuando el navegador está sin conexión y reanuda la sincronización cuando vuelve a estar en línea. La limitación de la cuota es de aproximadamente 100 KB, es decir, 8 KB por elemento.

Te recomendamos que uses storage.sync para conservar la configuración del usuario en los navegadores sincronizados. Si trabajas con datos sensibles del usuario, usa storage.session en su lugar. De forma predeterminada, storage.sync se expone a las secuencias de comandos de contenido, pero este comportamiento se puede cambiar llamando a chrome.storage.sync.setAccessLevel().

Métodos y eventos

Todas las áreas de almacenamiento implementan la interfaz StorageArea.

get()

El método get() te permite leer una o más claves de un objeto StorageArea.

getBytesInUse()

El método getBytesInUse() te permite ver la cuota que usa un StorageArea.

getKeys()

El método getKeys() te permite obtener todas las claves almacenadas en un StorageArea.

remove()

El método remove() te permite quitar un elemento de un StorageArea.

set()

El método set() te permite establecer un elemento en un StorageArea.

setAccessLevel()

El método setAccessLevel() te permite controlar el acceso a un StorageArea.

clear()

El método clear() te permite borrar todos los datos de un objeto StorageArea.

onChanged

El evento onChanged te permite supervisar los cambios en un objeto StorageArea.

Casos de uso

En las siguientes secciones, se muestran casos de uso comunes de la API de Storage.

Cómo responder a las actualizaciones de almacenamiento

Para hacer un seguimiento de los cambios realizados en el almacenamiento, agrega un objeto de escucha a su evento onChanged. Cuando cambia algo en el almacenamiento, se activa ese evento. El código de muestra detecta estos cambios:

background.js:

chrome.storage.onChanged.addListener((changes, namespace) => {
  for (let [key, { oldValue, newValue }] of Object.entries(changes)) {
    console.log(
      `Storage key "${key}" in namespace "${namespace}" changed.`,
      `Old value was "${oldValue}", new value is "${newValue}".`
    );
  }
});

Podemos llevar esta idea aún más lejos. En este ejemplo, tenemos una página de opciones que permite al usuario activar o desactivar un "modo de depuración" (la implementación no se muestra aquí). La página de opciones guarda inmediatamente la nueva configuración en storage.sync, y el trabajador de servicio usa storage.onChanged para aplicar el parámetro de configuración lo antes posible.

options.html:

<!-- type="module" allows you to use top level await -->
<script defer src="options.js" type="module"></script>
<form id="optionsForm">
  <label for="debug">
    <input type="checkbox" name="debug" id="debug">
    Enable debug mode
  </label>
</form>

options.js:

// In-page cache of the user's options
const options = {};
const optionsForm = document.getElementById("optionsForm");

// Immediately persist options changes
optionsForm.debug.addEventListener("change", (event) => {
  options.debug = event.target.checked;
  chrome.storage.sync.set({ options });
});

// Initialize the form with the user's option settings
const data = await chrome.storage.sync.get("options");
Object.assign(options, data.options);
optionsForm.debug.checked = Boolean(options.debug);

background.js:

function setDebugMode() { /* ... */ }

// Watch for changes to the user's options & apply them
chrome.storage.onChanged.addListener((changes, area) => {
  if (area === 'sync' && changes.options?.newValue) {
    const debugMode = Boolean(changes.options.newValue.debug);
    console.log('enable debug mode?', debugMode);
    setDebugMode(debugMode);
  }
});

Precarga asíncrona desde el almacenamiento

Dado que los service workers no se ejecutan todo el tiempo, las extensiones de Manifest V3 a veces necesitan cargar datos de forma asíncrona desde el almacenamiento antes de ejecutar sus controladores de eventos. Para ello, el siguiente fragmento usa un controlador de eventos action.onClicked asíncrono que espera a que se complete el objeto global storageCache antes de ejecutar su lógica.

background.js:

// Where we will expose all the data we retrieve from storage.sync.
const storageCache = { count: 0 };
// Asynchronously retrieve data from storage.sync, then cache it.
const initStorageCache = chrome.storage.sync.get().then((items) => {
  // Copy the data retrieved from storage into storageCache.
  Object.assign(storageCache, items);
});

chrome.action.onClicked.addListener(async (tab) => {
  try {
    await initStorageCache;
  } catch (e) {
    // Handle error that occurred during storage initialization.
  }

  // Normal action handler logic.
  storageCache.count++;
  storageCache.lastTabId = tab.id;
  chrome.storage.sync.set(storageCache);
});

Herramientas para desarrolladores

Puedes ver y editar los datos almacenados con la API en Herramientas para desarrolladores. Para obtener más información, consulta la página Cómo ver y editar el almacenamiento de extensiones en la documentación de DevTools.

Tipos

AccessLevel

Chrome 102 y versiones posteriores

Es el nivel de acceso del área de almacenamiento.

Enum

"TRUSTED_CONTEXTS"
Especifica contextos que se originan en la propia extensión.

"TRUSTED_AND_UNTRUSTED_CONTEXTS"
Especifica contextos que se originan fuera de la extensión.

StorageChange

Propiedades

  • newValue

    cualquier opción

    Es el valor nuevo del elemento, si hay un valor nuevo.

  • oldValue

    cualquier opción

    Es el valor anterior del elemento, si había uno.

Propiedades

local

Los elementos del área de almacenamiento local son locales para cada máquina.

Tipo

StorageArea y objeto

Propiedades

  • QUOTA_BYTES

    10485760

    Cantidad máxima (en bytes) de datos que se pueden almacenar en el almacenamiento local, según la conversión a cadena JSON de cada valor más la longitud de cada clave. Este valor se ignorará si la extensión tiene el permiso unlimitedStorage. Las actualizaciones que harían que se exceda este límite fallan de inmediato y establecen runtime.lastError cuando se usa una devolución de llamada, o una promesa rechazada si se usa async/await.

managed

Los elementos del área de almacenamiento managed se establecen mediante una política empresarial configurada por el administrador del dominio y son de solo lectura para la extensión. Si se intenta modificar este espacio de nombres, se produce un error. Para obtener información sobre cómo configurar una política, consulta Manifiesto para áreas de almacenamiento.

session

Chrome 102 y versiones posteriores MV3 y versiones posteriores

Los elementos del área de almacenamiento session se almacenan en la memoria y no se conservarán en el disco.

Tipo

StorageArea y objeto

Propiedades

  • QUOTA_BYTES

    10485760

    Es la cantidad máxima (en bytes) de datos que se pueden almacenar en la memoria, según la estimación del uso de memoria asignada de forma dinámica de cada valor y clave. Las actualizaciones que harían que se exceda este límite fallan de inmediato y establecen runtime.lastError cuando se usa una devolución de llamada o cuando se rechaza una promesa.

sync

Los elementos del área de almacenamiento sync se sincronizan con la Sincronización de Chrome.

Tipo

StorageArea y objeto

Propiedades

  • MAX_ITEMS

    512

    Es la cantidad máxima de elementos que se pueden almacenar en el almacenamiento de sincronización. Las actualizaciones que harían que se exceda este límite fallarán de inmediato y establecerán runtime.lastError cuando se use una devolución de llamada o cuando se rechace una promesa.

  • MAX_SUSTAINED_WRITE_OPERATIONS_PER_MINUTE

    1000000

    Obsoleto

    La API de storage.sync ya no tiene una cuota de operaciones de escritura sostenidas.

  • MAX_WRITE_OPERATIONS_PER_HOUR

    1800

    Es la cantidad máxima de operaciones de set, remove o clear que se pueden realizar por hora. Esto equivale a 1 cada 2 segundos, un límite inferior al límite a corto plazo de mayor cantidad de escrituras por minuto.

    Las actualizaciones que harían que se exceda este límite fallan de inmediato y establecen runtime.lastError cuando se usa una devolución de llamada o cuando se rechaza una promesa.

  • MAX_WRITE_OPERATIONS_PER_MINUTE

    120

    Es la cantidad máxima de operaciones set, remove o clear que se pueden realizar por minuto. Esto equivale a 2 por segundo, lo que proporciona una mayor capacidad de procesamiento que las escrituras por hora durante un período más corto.

    Las actualizaciones que harían que se exceda este límite fallan de inmediato y establecen runtime.lastError cuando se usa una devolución de llamada o cuando se rechaza una promesa.

  • QUOTA_BYTES

    102400

    Es la cantidad total máxima (en bytes) de datos que se pueden almacenar en el almacenamiento de sincronización, según la conversión a cadena JSON de cada valor más la longitud de cada clave. Las actualizaciones que harían que se exceda este límite fallan de inmediato y establecen runtime.lastError cuando se usa una devolución de llamada o cuando se rechaza una promesa.

  • QUOTA_BYTES_PER_ITEM

    8192

    Tamaño máximo (en bytes) de cada elemento individual en el almacenamiento de sincronización, según la conversión a cadena JSON de su valor más la longitud de su clave. Las actualizaciones que contengan elementos más grandes que este límite fallarán de inmediato y establecerán runtime.lastError cuando se use una devolución de llamada o cuando se rechace una promesa.

Eventos

onChanged

chrome.storage.onChanged.addListener(
  callback: function,
)

Se activa cuando cambian uno o más elementos.

Parámetros

  • callback

    función

    El parámetro callback se ve de la siguiente manera:

    (changes: object, areaName: string) => void

    • Cambios

      objeto

    • areaName

      string