Consulta esta página con frecuencia para conocer los cambios en las extensiones de Chrome, la documentación de las extensiones, la política relacionada y otros cambios. Encontrarás otros avisos publicados en el grupo de Google de Extensiones. En el programa de Chrome, se enumeran las fechas de lanzamiento de las versiones estables y beta.
Entrada de blog: Nuevo menú de extensiones
En Google I/O 2024, compartimos algunos diseños iniciales de los próximos cambios en el menú de extensiones, que les brindan a los usuarios más control sobre los sitios a los que pueden acceder las extensiones. Pronto comenzaremos a probar estos cambios, primero con un pequeño porcentaje de usuarios en Canary, y esperamos lanzarlos de forma más amplia en el futuro.
También presentamos la API de chrome.permissions.addHostAccessRequest()
.
Obtén más información en nuestra entrada de blog.
Chrome 132: Nueva propiedad inmovilizada en la API de Tabs
A partir de Chrome 132, la propiedad frozen
en la API de Tabs indica si el navegador inhabilitó una pestaña. Los mensajes enviados a pestañas inhabilitadas se pondrán en cola y se procesarán cuando se habiliten.
La API de Prompt en las extensiones de Chrome
La API de Prompt para extensiones ahora está disponible en una prueba de origen, por lo que puedes compilar extensiones de Chrome que usen Gemini Nano, nuestro modelo de lenguaje más eficiente, en el navegador.
Únete a la prueba de origen de la API de Prompt, que se ejecuta en Chrome 131 a 136, y comparte tus comentarios. Tus comentarios pueden afectar directamente la forma en que compilamos e implementamos las versiones futuras de esta API y todas las APIs de IA integradas.
Entrada de blog: Novedades de las extensiones de Chrome en octubre de 2024
Es hora de otro resumen de lo que sucede en las extensiones de Chrome: tenemos actualizaciones interesantes sobre la integración de IA, nuevas APIs, eventos y videos. Obtén más información en la edición de octubre de What's happening in Chrome Extensions.
Únete al desafío de IA integrada
Chrome lanzó el Desafío de IA integrada: Te invitamos a crear aplicaciones web y extensiones de Chrome innovadoras con las APIs y los modelos de IA integrados de Chrome y tener la oportunidad de ganar premios por un total de USD 65,000.
Regístrate y obtén más información en el sitio web del Desafío de IA integrada. No vemos la hora de ver lo que crearás cuando combines la Web con la IA.
Chrome 130: action.onUserSettingsChanged
A partir de Chrome 130, está disponible el evento action.onUserSettingsChanged. Esto se debe a una propuesta en el grupo de la comunidad de WebExtensions. Gracias a Microsoft por la contribución a Chromium.
Chrome 130: StorageArea.getKeys()
A partir de Chrome 130, el método getKeys() está disponible en la interfaz de StorageArea que usa la API de chrome.storage
. Esto se debe a una propuesta en el grupo de la comunidad de WebExtensions.
Chrome 128: Coincidencia del encabezado de respuesta en la solicitud de red declarativa
A partir de Chrome 128, agregamos compatibilidad con la coincidencia de encabezados de respuesta en la API de Declarative Net Request. Esta era una solicitud común, en particular para hacer coincidir el encabezado Content-Type, y diseñamos una API adecuada junto con el grupo comunitario de WebExtensions.
Actualizamos nuestra referencia de la API para incluir los nuevos campos responseHeaders
y excludedResponseHeaders
. Puedes usarlas para verificar la existencia y el valor de un encabezado determinado.
Como parte de esta actualización, agregamos una nueva sección de evaluación de reglas a nuestra documentación, en la que se explica cómo se hacen coincidir las reglas. En particular, para la coincidencia de encabezados, las reglas solo se pueden ejecutar una vez que se reciben los encabezados de respuesta, por lo que se aplican en una etapa posterior que otras reglas. Esto significa que la solicitud llega al servidor antes de bloquearse o redireccionarse.
Video: ¿Qué son las secuencias de comandos del contenido?
Obtén información sobre las secuencias de comandos del contenido en las extensiones de Chrome, incluido cómo registrar CSS y JavaScript para que se ejecuten en una página en particular. Mira el video completo.
Actualizaciones importantes de las políticas
El equipo de Chrome Web Store publicó una serie de actualizaciones en la página Políticas del programa para desarrolladores diseñadas para fomentar el desarrollo de productos de alta calidad, evitar comportamientos engañosos y garantizar el consentimiento informado de los usuarios. Rebecca Soares, la gerente de políticas de Chrome Web Store, resumió todas las actualizaciones en la entrada de blog Extensiones de Chrome: Actualizaciones importantes de políticas.
Entrada de blog: Novedades de las extensiones de Chrome en julio de 2024
En los últimos tres meses, lanzamos varias actualizaciones y funciones nuevas significativas, incluido el inicio de la baja gradual del manifiesto v2. Mantente al día con la edición de julio de What's happening in Chrome Extensions.
Video: ¿Qué es un código alojado de forma remota?
Patrick, del equipo de Extensiones de Chrome, explica el concepto de código alojado de forma remota (RHC) en las extensiones de Chrome. Obtén información sobre por qué ya no se permite el RHC, cómo detectarlo y qué hacer si tu extensión debe actualizarse. Mira el video completo.
Chrome 127: Nueva API de action.openPopup
A partir de Chrome 127, la API de action.openPopup
está disponible para todas las extensiones. Anteriormente, solo estaba disponible en Canary o para las extensiones instaladas por una política.
Video: Entrevista al equipo de Confianza y Seguridad
El equipo de DevRel de Extensiones de Chrome se reunió con el equipo de Confianza y seguridad que lidera las revisiones en Chrome Web Store para responder tus preguntas. Mira el video completo.
Entrada de blog: Comienza la baja gradual de Manifest V2
A partir del 3 de junio, en los canales beta, dev y Canary de Chrome, si los usuarios aún tienen instaladas extensiones de Manifest V2, algunos comenzarán a ver un banner de advertencia cuando visiten la página de administración de extensiones (chrome://extensions) para informarles que pronto dejarán de ser compatibles algunas extensiones (Manifest V2) que hayan instalado. Obtén más información en el anuncio oficial.
Actualizaciones de la IU del panel lateral
Hace poco, realizamos algunos cambios en la IU del panel lateral, como agregar un ícono de fijar y quitar el ícono global del panel lateral. Obtén más información en el PSA y consulta nuestra documentación y nuestros ejemplos actualizados.
Entrada de blog: Extensiones de Chrome en Google I/O 2024
Ya pasó otro Google I/O y cubrimos todas las emocionantes actualizaciones de extensiones. Ve a YouTube para mirar el video completo y lee nuestra entrada de blog para conocer algunos de los aspectos más destacados.
Omitir la revisión de los cambios aptos en las solicitudes de red declarativas
Chrome Web Store ahora te permite omitir la revisión de los cambios aptos cuando usas la API de Declarative Net Request. Obtén más información sobre la elegibilidad y cómo habilitar esta función en la documentación de Chrome Web Store.
deployPercentage disponible en la API de Chrome Web Store
Recientemente, actualizamos nuestra documentación de la API de Chrome Web Store para incluir información sobre deployPercentage
, que te permite asignar un porcentaje de una implementación de lanzamiento parcial. Obtén más información sobre deployPercentage
.
Chrome 126: Pruebas de origen en extensiones
Chrome 126 presenta un nuevo campo manifest.json: trial_tokens
, que te permite habilitar las pruebas de origen y de baja en todas las plataformas de extensión. Para obtener más información, consulta la guía.
Entrada de blog: Novedades de las extensiones de Chrome (abril de 2024)
Publicamos una nueva edición de What's Happening in Chrome Extensions. En la publicación, se analiza en qué estuvo trabajando el equipo de la extensión durante los últimos meses. Esto incluye la reversión de versión en Chrome Web Store, una mejor compatibilidad con Firebase Auth y más lanzamientos y actualizaciones de APIs.
Reversiones de versión en el Panel del desarrollador de Chrome Web Store
Revierte tu extensión a la versión publicada anterior en Chrome Web Store sin necesidad de revisión adicional. Para obtener más información, consulta la entrada de blog y la documentación.
Chrome 124: API de documentScan avanzada
Ahora está disponible en ChromeOS una API de documentScan
avanzada para descubrir y recuperar imágenes de los escáneres de documentos adjuntos.
Chrome 124: Compatibilidad con WebGPU en service workers
Desde Chrome 124, los trabajadores del servicio admiten WebGPU. Para un comienzo rápido, consulta el ejemplo de extensión de WebGPU.
Chrome 123: La API de Events admite el filtrado por bloques CIDR.
La API de Events ahora admite el filtrado por bloques de enrutamiento entre dominios sin clases (CIDR). Un bloque CIDR es una colección de direcciones IP que comparten un prefijo de red y la misma cantidad de bits. Anteriormente, un desarrollador que necesitaba filtrar varias direcciones IP debía configurar una regla de filtro para cada una de las direcciones en el rango del bloque. Ahora, cuando una extensión llama a addListener()
, una regla pasada significa que solo se llamará al controlador de eventos cuando la parte del host de una URL sea una dirección IP y se encuentre en cualquiera de los bloques CIDR especificados en un array.
Chrome Web Store: Actualizaciones de los requisitos de longitud de los nombres de las extensiones
En Chrome Web Store, ahora hay un límite universal de 75 caracteres para el campo "name"
de una extensión en manifest.json. Anteriormente, el límite para el inglés era de 45 caracteres, y no había restricciones para el campo "name"
en otras configuraciones regionales.
Originalmente, se diseñó para permitir diferencias culturales y lingüísticas que quizás no se puedan capturar en la misma cantidad de caracteres. Lamentablemente, algunos desarrolladores abusaron de esta función para enviar spam a la tienda. Como resultado, estamos implementando un nuevo límite universal, un aumento a 75 caracteres. Este límite abarca casi todas las extensiones de la tienda en la actualidad, por lo que es probable que no necesites realizar ninguna acción como resultado de este cambio. Si intentas subir una extensión que tiene un nombre más largo que el límite máximo, la tienda bloqueará la carga.
Entrada de blog: El recorrido de eyeo para probar la suspensión del trabajador de servicio
En esta publicación del equipo de Extension Engine de eyeo, analizamos el problema de probar los trabajadores de servicio de extensión. En Manifest V2, las extensiones se alojaban en una página en segundo plano, que estaba activa durante todo el ciclo de vida de la extensión. En su lugar, el manifiesto V3 usa trabajadores del servicio que, por diseño, apagan los recursos cuando no son necesarios para conservarlos. Esto plantea ciertos desafíos de prueba. En esta publicación, se explica cómo eyeo abordó estos desafíos.
Chrome 123: Las alarmas ahora se ejecutan cuando el dispositivo está inactivo.
Las alarmas configuradas con la API de chrome.alarms
ya no se retrasan cuando un dispositivo entra en modo de suspensión. Cuando el dispositivo se active, la alarma se activará una vez, sin importar cuántas alarmas se hayan perdido. Por ejemplo, supongamos que una alarma está configurada para sonar una vez por hora y el dispositivo en el que se encuentra está inactivo desde las 12:55 a.m. hasta las 2:05 a.m. En ese caso, solo la alarma de las 2:00 a.m. activa el evento onAlarm
.
Se activará lo más cerca posible de las 2:00 a.m. y, de inmediato, cuando se active un dispositivo si estaba inactivo.
Este cambio permite que Chrome cumpla con el comportamiento acordado en el Grupo comunitario de extensiones web.
Entrada de blog: Cambios en el comportamiento de bfcache con puertos de mensajes de extensión
La memoria caché atrás/adelante (bfcache) es una optimización del navegador que permite la navegación instantánea hacia adelante y hacia atrás. A partir de Chrome 123, cuando se almacena una página con un puerto de extensión abierto en la bfcache, se cierra el canal de mensajes, lo que significa que no se enviarán mensajes a esa página.
En consecuencia, las secuencias de comandos de extensión deben escuchar eventos del ciclo de vida, como onDisconnect
, y configurar una conexión nueva cuando se restablezca la página desde BFCache.
Para obtener más información y código de muestra, consulta Cambios en el comportamiento de BFCache con puertos de mensajes de extensión.
Chrome 122: Compatibilidad con promesas en las APIs de extensiones asíncronas
Terminamos de implementar la compatibilidad con Promise para todos los métodos de la API de la extensión asíncrona. Esto se hizo para modernizar los métodos de la API mejorando la ergonomía de la interacción con las operaciones asíncronas. Algunos métodos (por ejemplo, desktopCapture.chooseDesktopMedia()
) solo admiten devoluciones de llamada porque sus plataformas actuales no son compatibles con las promesas. Para la retrocompatibilidad, las devoluciones de llamada aún se admiten. Si encuentras una promesa que falla, informa un error.
Nueva guía para la comunicación en tiempo real
Acabamos de publicar guías sobre las opciones en tiempo real en las extensiones. Las actualizaciones en tiempo real proporcionan una ruta de comunicación instantánea desde tus servidores directamente a las instalaciones de tu extensión. Además, tenemos una nueva guía para usar chrome.gcm, el notificador web push.
Nueva orientación y muestra: Prueba la finalización del trabajador de servicio
Acabamos de publicar una guía sobre cómo probar la finalización del trabajador de servicio con Puppeteer. El ejemplo adjunto lo demuestra en Puppeteer y Selenium.
Se actualizó el ejemplo para la mensajería nativa.
Acabamos de publicar un ejemplo actualizado para los mensajes nativos. Esta API permite que tu extensión se inicie y se comunique con otra aplicación. Gracias al colaborador de GitHub Shubham-Rasal por su trabajo en esto.
Chrome 121: Nueva propiedad lastAccessed en tabs.Tab
Se agregó una propiedad nueva llamada lastAccessed
al objeto tabs.Tab
. Esta propiedad indica cuándo se activó la pestaña por última vez. El valor que se muestra está en milisegundos desde el ciclo de entrenamiento.
Chrome 121: Las claves "en segundo plano" no admitidas ahora muestran una advertencia
En el cambio de Manifest V2 a Manifest V3, se cambiaron los elementos secundarios de la clave de manifiesto "background"
para admitir el reemplazo de secuencias de comandos en segundo plano por service workers de extensión. Anteriormente, agregar las claves de Manifest V2 "scripts"
, "page"
o "persistent"
a la clave "background"
de una extensión de Manifest V3 generaba un error. La presencia de estas claves ahora activa una advertencia.
Esto se hace para habilitar el uso de un solo archivo de manifiesto en extensiones en varios navegadores, según una propuesta en el grupo de la comunidad.
Chrome 120: Se redujo el nivel de detalle mínimo de las alarmas a 30 segundos.
A partir de Chrome 120, las extensiones de Manifest V3 pueden usar la API de chrome.alarms
con retrasos o períodos de 30 segundos, en lugar de requerir valores de 60 segundos o más.
Entrada de blog: Se reanuda la transición a Manifest V3
Se actualizó el cronograma de compatibilidad con Manifest V2. Consulta nuestra entrada de blog de noviembre de 2023 para obtener más información.
Entrada de blog: Mejoras en la compatibilidad con el filtrado de contenido en Manifest V3
Obtén información sobre cómo mejoramos la API de declarativeNetRequest en nuestra nueva entrada de blog.
Entrada de blog: Novedades de Chrome 120 para extensiones
Recientemente, se lanzó la versión beta de Chrome 120. Para obtener un resumen de las actualizaciones importantes relevantes para los desarrolladores de extensiones, lee nuestra nueva entrada de blog: Novedades de Chrome 120 para extensiones. Esta versión también marca un hito importante, ya que quita los dos últimos elementos (userScripts y el controlador de archivos en ChromeOS) de la lista de brechas críticas de la plataforma.
Aviso importante: Cambio en el manejo de las URLs de las políticas de privacidad en el Panel del desarrollador
Las políticas de privacidad del Panel del desarrollador ahora se agregan a nivel del artículo. Esto te permite proporcionar una política de privacidad diferente por elemento. Obtén más información sobre este cambio en nuestro PSA.
Video: Charla con Matt Frisbie
Acabamos de publicar un video nuevo en el canal de YouTube de Chrome for Developers en el que conversamos con el experto en desarrolladores de Google y autor Matt Frisbie. Míralo aquí.
Nueva guía para probar extensiones
Acabamos de publicar una nueva guía sobre cómo escribir pruebas automatizadas para extensiones, incluida cómo escribir pruebas de unidades, una guía general y un instructivo sobre pruebas de extremo a extremo.
Entrada de blog: Novedades de las extensiones de Chrome (octubre de 2023)
Acabamos de publicar la segunda edición de What's Happening in Chrome Extensions. En la publicación, se analiza en qué ha estado trabajando el equipo de la extensión en los últimos meses, lo que incluye abordar los problemas de estabilidad del trabajador de servicio y avanzar mucho en la eliminación de todas las brechas de la plataforma de MV3. También compartimos las próximas versiones de las APIs, como la API de Reading List y la API de User Scripts.
Se aumentaron los límites de los conjuntos de reglas estáticos en la API de Declarative Net Request
Después de los comentarios en el grupo de la comunidad de Extensiones web, aumentaremos significativamente el límite de conjuntos de reglas estáticos habilitados de 10 a 50. Además, aumentaremos de 50 a 100 la cantidad total de conjuntos de reglas estáticos permitidos. Actualmente, esta función está disponible en Canary.
Se mejoró la guía sobre el código alojado de forma remota
Un requisito de Manifest V3 es que las extensiones ya no pueden usar código alojado de forma remota. Si bien esto ha sido parte de nuestra guía de migración desde el principio, pensamos que valía la pena mejorar la orientación sobre este problema. Esa página ahora proporciona más información, en la que se describe lo que aún es posible en Manifest V3 y se brinda más información sobre las estrategias de actualización.
Hay una incorporación relacionada en la solución de problemas relacionados con incumplimientos en Chrome Web Store. Se agregó una nueva sección en la que se describen los motivos comunes por los que se rechazan las extensiones con código alojado de forma remota.
Chrome 118: isUrlFilterCaseSensitive ahora es falso de forma predeterminada.
A partir de Chrome 118, la propiedad isUrlFilterCaseSensitive
de la API de chrome.declarativeNetRequest cambió a false
de forma predeterminada. Si deseas mantener el comportamiento anterior, puedes establecer isUrlFilterCaseSensitive
en true
de forma explícita en tus reglas de declarativeNetRequest.
Esto se debe a discusiones en el grupo de la comunidad de Extensiones web. Firefox y Safari ya implementaron un cambio similar.
Documentación sobre las APIs de cookies y almacenamiento web
Publicamos una nueva guía sobre cómo funcionan las APIs de cookies y almacenamiento web en las extensiones de Chrome. Incluye detalles sobre los cambios en la partición de cookies y almacenamiento en Privacy Sandbox, un proyecto en curso para dar de baja las cookies de terceros a través de la creación de una serie de nuevas APIs de la plataforma web, y detalles sobre cómo funcionan en las extensiones.
Ahora se pueden buscar muestras de extensiones
Recientemente, creamos una página que te permite buscar muestras de extensiones de Chrome. La página de búsqueda tiene varias opciones. Un cuadro de búsqueda te permite buscar texto en los títulos de muestra. Puedes restringir la búsqueda por permiso o API de extensión. Un filtro adicional te permite restringir la búsqueda a muestras funcionales (casos de uso) o de API.
Xuezhou Dai, participante de Google Summer of Code, creó esta nueva página de ejemplo, que también contribuyó con varias muestras nuevas. Puedes leer sobre sus experiencias del verano pasado en su entrada en nuestro blog.
Como antes, nuestras muestras de código siguen disponibles en GitHub para clonarse o bifurcarse.
Chrome 118: Se realizaron cambios en el archivo de apertura: URLs de esquemas
A partir de Chrome 118, las extensiones deberán tener habilitado el parámetro de configuración "Permitir acceso a URLs de archivos" desde la página chrome://extensions
para abrir URLs de esquema file:// con las APIs de Tabs o Windows. Para verificar este acceso de forma programática, llama a chrome.extension.isAllowedFileSchemeAccess()
. Firefox ya restringe las URLs de los archivos, y Safari admite el cambio. Para obtener más información, lee la publicación en el Grupo de Google de extensiones.
Chrome 117: Se expandieron las protecciones de URL en las navegaciones de la API de la extensión
Anteriormente, la navegación activada desde las llamadas a la API de la extensión para tabs.update()
, tabs.create()
y windows.create()
emitía un error para algunas URLs chrome://. Además, estaba prohibido llamar a tabs.update()
con una URL de JavaScript. En la versión 117, estas protecciones en las URLs de JavaScript se expandieron al método tabs.create()
y se agregaron varias URLs chrome:// adicionales a la lista de URLs prohibidas que se aplica a todos los métodos mencionados anteriormente.
Se mejoró la guía para la API de declarativeNetRequest
La API de chrome.declarativeNetRequest
bloquea o modifica las solicitudes de red mediante la especificación de reglas declarativas. Esto permite que las extensiones modifiquen las solicitudes de red sin interceptarlas ni ver su contenido, lo que proporciona más privacidad a los usuarios. También es difícil de usar. Con eso en mente, reescribimos la guía de una manera que creemos que ofrece una imagen más clara de cómo implementar conjuntos de reglas declarativos. Lee la nueva sección en el vínculo anterior.
Cómo usar tu cuenta de Google Analytics con Chrome Web Store
Chrome Web Store ofrece integración con Google Analytics, lo que te permite ver las estadísticas de tu ficha de Chrome Web Store, además de la vista que se ofrece en el Panel del desarrollador. Para obtener más información, consulta Cómo usar tu cuenta de Google Analytics con Chrome Web Store.
Chrome 115: Herramientas para desarrolladores omite las secuencias de comandos de contenido de forma predeterminada
Las secuencias de comandos de contenido insertadas ahora se encuentran en la lista de elementos ignorados de DevTools de forma predeterminada. Esto no afecta los puntos de interrupción, pero significa que las secuencias de comandos de contenido se omitirán durante la depuración y se ignorarán las excepciones de estas secuencias. Cuando una secuencia de comandos del contenido está abierta en la pestaña Fuentes, un banner te alerta si está activada y te brinda la opción de quitarla de la lista de elementos ignorados. Para desactivar este comportamiento, abre DevTools, ve a Configuración y, luego, a Lista de elementos ignorados. Para obtener más información, consulta Novedades de DevTools.
Versión beta de Chrome 116: Más de lo que podemos incluir aquí
Chrome 116 es una gran versión para las extensiones. Ahora puedes abrir paneles laterales de forma programática. Un nuevo método te permite saber si hay un documento fuera de la pantalla activo. Se realizaron varias mejoras en los service workers. Hay suficientes mejoras en la versión 116 como para escribir una entrada de blog para hablar de ellas. Chrome 116 está en versión beta desde el 19 de julio.
Entrada de blog: Qué sucede en las extensiones de Chrome
Acabamos de publicar una descripción general de los cambios y mejoras en las extensiones de este año. En la publicación, se analizan las nuevas funciones principales del año, como la API del panel lateral, las mejoras de los trabajadores del servicio y los documentos fuera de pantalla. También podrás ver en qué estamos trabajando este trimestre. En el artículo, se incluye mucho más, con vínculos a todos.
Nueva guía y ejemplo: Aprende a usar Google Analytics 4 en tu extensión de Chrome
Publicamos nuevos ejemplos y lineamientos de Google Analytics y geolocalización:
- Una versión actualizada de nuestra guía de Google Analytics en la que se explica cómo puedes usar Google Analytics 4 en tu extensión de Chrome. También agregamos una muestra funcional de Google Analytics 4 a nuestro repositorio de muestras de GitHub. Consulta
google-analytics.js
para obtener el código relevante relacionado con Google Analytics. - Una nueva guía de ubicación geográfica y tres ejemplos que muestran cómo acceder a la ubicación geográfica en los trabajadores del servicio, las secuencias de comandos de contenido, las ventanas emergentes y los paneles laterales.
Chrome 115: Especifica varios motivos en chrome.offscreen.createDocument().
Ahora puedes especificar varias enums reason
cuando llames a chrome.offscreen.createDocument()
. Úsalo cuando se use un documento fuera de la pantalla para varios fines diferentes. El navegador usa los motivos proporcionados para determinar la vida útil del documento fuera de la pantalla.
Nueva herramienta: Herramienta de prueba de actualizaciones de extensiones
Acabamos de lanzar la herramienta de prueba de actualizaciones de extensiones, un servidor de actualización de extensiones local que se puede usar para probar actualizaciones de extensiones de Chrome durante el desarrollo local, incluidos los otorgamientos de permisos. La herramienta muestra el flujo de actualización del usuario, lo que incluye mantener una extensión inhabilitada hasta que un usuario otorgue los permisos solicitados recientemente. Esta herramienta es particularmente útil para simular los cambios de permisos solicitados cuando se actualiza una extensión de Manifest V2 a Manifest V3.
Chrome 114: Nueva API de Side Panel
Presentamos la nueva API de Side Panel, una plataforma complementaria que permite a los usuarios acceder a herramientas junto con el contenido que están explorando. Para obtener más información, consulta la referencia de la API del panel lateral. Además, agregamos muchos ejemplos de paneles laterales a nuestro repositorio de muestras de GitHub. También compartimos más información sobre los paneles laterales en la nueva entrada de blog Cómo diseñar una experiencia del usuario superior con la nueva API de Side Panel. También se revisaron nuestra política de lineamientos de calidad y las prácticas recomendadas para brindar más orientación sobre la creación de extensiones de panel lateral de alta calidad.
Tus comentarios son importantes para crear esta API. Comparte tus ideas y solicitudes de funciones en chromium-groups. No te pierdas las novedades a medida que seguimos mejorando la API del Panel lateral.
Muestras nuevas: WASM en extensiones
Hay dos ejemplos nuevos disponibles que demuestran cómo usar WASM en una extensión:
- En Cómo usar WASM en Manifest V3, se muestra el método general para incluir un módulo WASM.
- En Cómo usar WASM como un módulo en Manifest V3, se muestra cómo usarlo en un módulo.
Agradecemos especialmente al colaborador de GitHub @daidr por estos ejemplos.
Orientación actualizada para la migración a Manifest V3
Actualizamos la sección Problemas conocidos de nuestra guía de migración a Manifest V3 con una lista actualizada de las brechas en la plataforma de extensiones que tenemos la intención de cerrar antes de anunciar un nuevo cronograma de baja de Manifest V2.
Cómo grabar audio y video con Manifest V3
Acabamos de publicar un nuevo artículo llamado Grabación de audio y captura de pantalla, en el que se explica cómo grabar audio o video desde una pestaña, una ventana o una pantalla en el manifiesto V3. En este artículo, se describen varios enfoques para la grabación que involucran la API de chrome.tabCapture
y la función getDisplayMedia()
.
Chrome 114: Se aumentó la cuota de storage.local
Aumentamos la cuota de la propiedad storage.local
a aproximadamente 10 MB. Se aceptó en el grupo de la comunidad de extensiones web. Esto alinea storage.local
con storage.session
, que cambió en Chrome 112.
Nuevo instructivo y ayuda sobre el trabajador del servicio de extensión
Los trabajadores de servicio son una parte integral de las extensiones de Chrome. Acabamos de publicar un instructivo en el que se explican los conceptos básicos para registrar, depurar e interactuar con los trabajadores de servicio. También agregamos una nueva guía de trabajadores del servicio en la que se explican conceptos importantes con más detalle. Ampliaremos esta sección en los próximos meses.
Más sugerencias para solucionar problemas relacionados con los incumplimientos de la tienda web
Para facilitar la publicación en Chrome Web Store, agregamos nueva orientación en dos áreas. La guía sobre la funcionalidad mínima se centra en proporcionarles beneficios a los usuarios y enriquecer su experiencia de navegación. La guía para los anuncios de afiliados consiste en informar a los usuarios sobre las extensiones que usan vínculos o códigos de afiliados para la monetización y darles cierto control, ya que se requiere una acción del usuario antes de la inclusión.
Nuevas instrucciones para el convertidor de manifiestos de extensiones
Volvemos a escribir el archivo readme del Extension Manifest Converter para que sea más fácil ver lo que debes hacer después de ejecutar la herramienta. El convertidor ayuda a migrar extensiones compiladas en Manifest V2 a Manifest V3. En el nuevo archivo readme, se describe lo que hace la herramienta con palabras que coinciden estrechamente con las de la lista de tareas de la guía de migración. El convertidor no hace todo, pero elimina muchas tareas que no requieren una decisión humana.
Chrome 113: Nuevos motivos para documentos fuera de la pantalla
Se agregaron dos nuevos tipos de motivos a la API de Offscreen Documents. Usa LOCAL_STORAGE
para acceder a la API de localStorage de la plataforma web. Usa WORKER
cuando crees trabajadores web.
Google Analytics 4 ahora está disponible en el panel para desarrolladores
El Panel del desarrollador de Chrome Web Store ahora admite Google Analytics 4 (GA4). Simplificamos la configuración de Google Analytics y facilitamos la administración de accesos para los publicadores de grupos. Si anteriormente usaste Google Universal Analytics para hacer un seguimiento de la actividad de tu ficha de Play Store, deberás tomar medidas antes del 1 de julio de 2023 para asegurarte de seguir recibiendo datos sobre ella. Para obtener más información, consulta la entrada en el Grupo de Google de Extensiones de Chromium.
La API de File Handling llega a ChromeOS
La API de File Handler está disponible para experimentar en ChromeOS en Canary para las versiones 112 y 113. Permite que las extensiones de ChromeOS abran archivos con tipos de MIME y extensiones de archivo especificados. Para implementar el manejo de archivos, agrega un conjunto de reglas a manifest.json
. Esta función funciona de la misma manera que para las apps web progresivas. Para obtener más información, consulta el artículo en otro lugar de este sitio.
Para habilitar el manejo de archivos, haz lo siguiente:
- A partir de la versión 112, inicia Chrome con la marca
--enable-features=ExtensionWebFileHandlers
. - A partir de la versión 113, pega
os://flags/#extension-web-file-handlers
en la barra omni de Chrome y selecciona "Habilitado" en el menú desplegable.
Esperamos lanzar esta función en Chrome 115 a fines de junio. No te pierdas las novedades.
Nuevos ejemplos: Declaraciones dinámicas y inserción programática
Creamos un ejemplo nuevo para la API de chrome.scripting
. En él, se muestran las declaraciones dinámicas, en las que se registra una secuencia de comandos de contenido en el tiempo de ejecución, y la inserción programática, en la que se ejecuta una secuencia de comandos en una pestaña que ya está abierta.
Muestras nuevas: Casos de uso de la solicitud de red declarativa
Hay tres ejemplos nuevos disponibles que demuestran la API de Declarative Net Request. Cada uno demuestra la implementación de un solo caso de uso. En el primero, se muestra cómo bloquear las cookies. Los dos restantes muestran el bloqueo y el redireccionamiento de URLs.
Chrome 112: Se aumentó la cuota de storage.session
A partir de Chrome 112, la cuota de la propiedad storage.session
aumentó a aproximadamente 10 MB. Se acordó en el grupo de la comunidad de extensiones web: https://github.com/w3c/webextensions/issues/350
Chrome 109: Documentos fuera de pantalla
Los documentos fuera de pantalla ahora están disponibles en las extensiones de Manifest V3. Estos ayudan con la transición de las páginas en segundo plano a los service workers de extensiones, ya que proporcionan compatibilidad con las APIs y funciones relacionadas con el DOM. Para obtener más información, lee la entrada de blog.
Chrome 110: Si una extensión está habilitada
El método chrome.action.isEnabled()
verifica de forma programática si se habilitó una extensión para una pestaña específica. Esto te evita mantener el estado habilitado de tus pestañas. Este nuevo método toma un ID de pestaña y una referencia a una devolución de llamada, y muestra un valor booleano. Tiene una limitación: las pestañas creadas con chrome.declarativeContent
siempre muestran un valor falso.
(Recientemente, el espacio de nombres chrome.action
recibió nuevos métodos para controlar el aspecto de las insignias de extensión. Para obtener más información, consulta Cómo configurar los colores de las insignias.
Chrome 110: Cambio en el tiempo de espera de inactividad del servicio trabajador
Anteriormente, un trabajador del servicio de extensión se cerraba con frecuencia a los cinco minutos. Cambiamos este comportamiento para que se asemeje más al ciclo de vida del trabajador de servicio en la Web. Un trabajador de servicio de extensión se cerrará después de treinta segundos de inactividad o si una sola actividad tarda más de 5 minutos en procesarse. Para obtener más información, consulta Mayores tiempos de vida del trabajador de servicio de extensión.
Publicación: Se pausa la baja gradual de Manifest V2
Se están revisando los cronogramas de baja de Manifest V2 y se posponen los experimentos programados para principios de 2023. Para obtener más información, lee la actualización en el grupo de Google chromium-extensions.
Chrome 110: Cómo configurar los colores de las insignias
El espacio de nombres chrome.action
tiene dos métodos nuevos para brindarte más control sobre las insignias de extensión de apariencia. Los métodos setBadgeTextColor()
y getBadgeTextColor()
permiten que una extensión cambie y consulte el color del texto de la insignia del ícono de la barra de herramientas. Cuando se usan con setBadgeBackgroundColor
y getBadgeBackgroundColor
, estos nuevos métodos te permiten aplicar la coherencia de diseño y marca.
Entrada de blog: Más detalles sobre la transición a Manifest V3
Aclaramos el cronograma de baja de Manifest V2. También se actualizó el cronograma de compatibilidad con Manifest V2 para reflejar esta información.
Actualización de la documentación: Problemas conocidos durante la migración a Manifest V3
Elaboramos una lista de las funciones principales que se encuentran en desarrollo y los errores abiertos. Nuestro objetivo con esta página es ayudar a los desarrolladores a comprender mejor el estado actual de la plataforma y a qué funciones pueden segmentar su contenido mientras se preparan para el futuro.
Chrome Web Store: Se quitó la carga de imágenes de "tarjeta promocional grande"
Chrome Web Store quitó la IU de carga de "tarjeta de promoción grande" de la pestaña Ficha de Play Store del elemento en el panel del desarrollador. Este cambio no afecta la experiencia del usuario final, ya que estas imágenes no se usaban en la IU para consumidores. Consulta esta entrada de chromium-extensions para obtener más detalles.
Chrome 106: Permite que las páginas en URLs de file:// accedan a recursos accesibles en la Web
Los orígenes opacos, como los iframes en zona de pruebas y la importación dinámica, también deberían poder acceder a recursos accesibles a través de la Web, según crbug.com/1219825#c11.
Chrome 106: Se corrigió un error que permitía argumentos finales incorrectos en algunas funciones de API asíncronas.
Anteriormente, Manifest V3 podía proporcionar un argumento final no válido cuando se llamaba a APIs asíncronas, y Chrome no generaba errores. Con esta corrección, Chrome ahora informará correctamente que no hay una firma coincidente. Se recomienda a los desarrolladores que verifiquen sus extensiones en Canary para detectar errores en caso de que usen accidentalmente una firma incorrecta para una llamada a la API que se interrumpirá con esta corrección de errores.
Entrada de blog: Renovación de las estadísticas de Chrome Web Store
Chrome Web Store tiene una experiencia renovada de estadísticas de artículos para el Panel del desarrollador de Chrome Web Store. El nuevo panel es más fácil de entender de un vistazo y consolida la información más útil en primer lugar. Lee la entrada de blog para obtener más información.
Chrome 105: promesas para la API de Identity
Las funciones de la API de Identity ahora
admiten llamadas basadas en promesas. Esto incluye un ligero cambio en la superficie de identity.getAuthToken()
, en el que la devolución asíncrona establecida en una llamada basada en promesas tendrá "token" y "grantedScopes" como parámetros en un solo objeto (a diferencia de la versión de devolución de llamada que los recibe como argumentos separados para la devolución de llamada).
Chrome 104: Nueva API de favicons para Manifest V3
Las extensiones de Manifest V3 ahora pueden acceder a los íconos de favoritos con un nuevo patrón de URL: chrome-extension://<id>/_favicon/
, en el que chrome://favicons
de la plataforma de manifiesto v2. Consulta la documentación de la API de Favicon para obtener más información.
Actualización de la documentación: Divulgación del desarrollador comerciante o no comerciante
Se agregó la identificación de desarrollador comerciante o no comerciante, que informa a los desarrolladores que deben autodeclarar con precisión su estado de comerciante o no comerciante.
Chrome 103: Wasm en Manifest V3 requiere wasm-unsafe-eval
Chrome ya no otorga script-src: wasm-unsafe-eval
a las extensiones de forma predeterminada. Las extensiones que usan WebAssembly ahora deben agregar explícitamente esta directiva y el valor a extension_pages
en sus declaraciones content_security_policy
.
Chrome 103: Los cambios en las combinaciones de teclas de MV3 se aplican de inmediato
Cuando cambias la combinación de teclas de una extensión de Manifest V3 en chrome://extensions/shortcuts
, ahora las actualizaciones se aplican de inmediato. Anteriormente, la extensión se debía volver a cargar antes de que se aplicara el cambio.
Chrome 102: Secuencias de comandos de contenido dinámico en el mundo principal
Las secuencias de comandos de contenido registradas de forma dinámica ahora pueden especificar el mundo en el que se insertarán los recursos. Consulta scripting.registerContentScripts()
para obtener más información.
Chrome 102: Nuevo campo de manifiesto "optional_host_permissions"
Las extensiones de Manifest V3 ahora pueden especificar la clave optional_host_permissions
en manifest.json. Esto permite que las extensiones de Manifest V3 declaren patrones de coincidencia opcionales para hosts, al igual que las extensiones de Manifest V2 podrían hacerlo con la clave optional_permissions
.
Chrome 102: Propiedad injectImmediately en scripting.executeScript().
chrome.scripting.executeScript()
ahora acepta una propiedad injectImmediately
opcional en su argumento injection
. Si está presente y se establece como verdadero, la secuencia de comandos se insertará en el destino lo antes posible, en lugar de esperar a document_idle
. Ten en cuenta que esto no garantiza que la secuencia de comandos se inserte antes de que se cargue la página, ya que la página continúa cargándose mientras se realiza la llamada a la API.
Chrome 102: Compatibilidad con la API de Omnibox en Manifest V3
La API de Omnibox ahora se puede usar en extensionesbasadas en trabajadores de servicio. Anteriormente, algunos de los métodos de esta API arrojaban una excepción en la invocación debido a dependencias internas en las funciones de DOM.
Chrome 102: Se permite wasm-unsafe-eval en el CSP de Manifest V3.
Las extensiones de Manifest V3 ahora pueden incluir wasm-unsafe-eval
en sus declaraciones content_security_policy
. Este cambio permite que las extensiones de Manifest V3 usen WebAssembly.
Chrome 102: Nueva API de storage.session
Las extensiones de Manifest V3 ahora pueden usar el almacenamiento en memoria storage.session .
Actualización de Documentos: Descubrimiento de artículos de Chrome Web Store
Descubrimiento en Chrome Web Store ofrece una descripción general de cómo los usuarios encuentran elementos en Chrome Web Store y cómo nuestros editores seleccionan los elementos para mostrar.
Chrome 101: Se mejoraron las condiciones de dominio de declarativeNetRequest
Se actualizaron las condiciones de la regla declarativeNetRequest para permitir que las extensiones segmenten mejor las solicitudes según los dominios "request" y "initiator" de la solicitud. Las propiedades de condición relevantes son initiatorDomains
, excludedInitiatorDomains
, requestDomains
y excludedRequestDomains
. Consulta también esta conversación de chromium-extensions.
Chrome 100: Se resolvió el problema con scripting.executeScript() en pestañas recién creadas.
Se solucionó un problema de larga data por el que podía fallar la llamada a scripting.executeScript()
en una pestaña o ventana recién creada.
Chrome 100: El puerto de mensajería nativa mantiene activo el trabajador de servicio
La conexión a un host de mensajería nativa con chrome.runtime.connectNative()
en el trabajador de servicio de una extensión debería mantener el trabajador de servicio activo mientras el puerto esté abierto.
Chrome 100: omnibox.setDefaultSuggestion() admite promesas y devoluciones de llamada.
El método omnibox.setDefaultSuggestion()
ahora muestra una promesa o acepta una devolución de llamada para permitir que los desarrolladores determinen cuándo se configuró correctamente la sugerencia.
Chrome 100: Compatibilidad con i18n.getMessage() en los service workers de extensiones
La API de chrome.i18n.getMessage()
ahora se admite en contextos de service worker de extensión.
Chrome 99: match_origin_as_fallback en Canary
Las secuencias de comandos de contenido ahora pueden especificar la clave match_origin_as_fallback
para insertarla en marcos que se relacionen con un marco coincidente, incluidos los marcos con URLs about:
, data:
, blob:
y filesystem:
. Consulta la documentación de las secuencias de comandos de contenido para obtener más información.
Chrome 99: Se agregó compatibilidad con el service worker de extensiones para esquemas file: en Canary.
Las extensiones de Manifest V2 y Manifest V3 basadas en service workers ahora pueden usar la API de Fetch para solicitar URLs de esquema file:
. El acceso a las URLs de esquema file:
aún requiere que el usuario habilite "Permitir acceso a las URLs de archivo" para la extensión en la página chrome://extensions
.
Chrome 99: Se agregó compatibilidad con las APIs de mensajería en Canary
Se agregó compatibilidad con promesas a tabs.sendMessage
, runtime.sendMessage
y runtime.sendNativeMessage
para extensiones compiladas para Manifest V3.
Actualización de la documentación: Documentación de revisión de Chrome Web Store
Se agregó una nueva página de referencia que proporciona una descripción general del proceso de revisión de Chrome Web Store y explica cómo se controla la aplicación de la política del programa para desarrolladores.
Chrome 98: scripting.executeScript() y scripting.insertCSS() aceptan varios archivos.
Los métodos executeScript()
y insertCSS()
de la API de Scripting ahora aceptan varios archivos. Anteriormente, estos métodos requerían un array con una sola entrada de archivo.
Actualización de documentos: Actualizaciones para solucionar problemas relacionados con infracciones de políticas
Se actualizó la página Solución de problemas relacionados con incumplimientos en Chrome Web Store para brindar a los desarrolladores una guía más detallada sobre los motivos comunes de rechazo.
Chrome 96: Se expandió la compatibilidad con promesas a 27 APIs más.
Esta versión contiene muchas más actualizaciones de promesas que cualquier versión anterior. Las actualizaciones incluyen APIs de extensiones generales y específicas de ChromeOS. Expande las siguientes secciones para obtener más detalles.
APIs de Extensions
Varias APIs ahora admiten promesas en Manifest V3.
chrome.browsingData
chrome.commands
chrome.contentSettings
chrome.debugger
chrome.downloads
chrome.enterprise.hardwarePlatform
chrome.fontSettings
chrome.history
chrome.instanceID
chrome.permissions
chrome.processes
chrome.search
chrome.sessions
chrome.topSites
Además, las APIs que usan el prototipo ChromeSetting
ahora también admiten promesas. Este cambio afecta a las siguientes APIs.
APIs de ChromeOS
chrome.certificateProvider
chrome.documentScan
chrome.enterprise.deviceAttributes
chrome.enterprise.networkingAttributes
chrome.fileBrowserHandler
chrome.fileSystemProvider
chrome.loginState
chrome.printingMetrics
chrome.wallpaper
Chrome 96: Secuencias de comandos de contenido dinámico
La API de chrome.scripting
ahora admite registrar, actualizar, desregistrar y obtener una lista de secuencias de comandos de contenido durante el tiempo de ejecución. Anteriormente, las secuencias de comandos de contenido solo se podían declarar de forma estática en el archivo manifest.json de una extensión o insertarse de forma programática en el tiempo de ejecución con chrome.scripting.executeScript()
.
Actualización de la documentación: Cronograma de compatibilidad con Manifest V2
El cronograma de transición de Manifest V2 a V3 se anunció en esta entrada de blog y se publicó una página de cronograma más detallada.
Chrome 96: Permiso declarativeNetRequestWithHostAccess
El nuevo permiso declarativeNetRequestWithHostAccess
permite que las extensiones usen la API de chrome.declarativeNetRequest
en los sitios para los que la extensión tiene permisos de host. Esto también permite que las extensiones existentes de Manifest V2 que usan webRequest
, webRequestBlocking
y el permiso de host específico del sitio migren a la API de chrome.declarativeNetRequest
sin que el usuario deba aprobar permisos nuevos.
Chrome 95: Inyección de secuencias de comandos directamente en las páginas
El método executeScript()
de la API de chrome.scripting
ahora puede insertar secuencias de comandos directamente en el mundo principal de una página. Anteriormente, las extensiones solo podían insertarse directamente en el mundo aislado de la extensión. Para obtener más información sobre los mundos aislados, consulta la documentación sobre secuencias de comandos de contenido.
Chrome 95: Se agregó compatibilidad con la API de Storage
Los métodos de la versión V3 del manifiesto de la API de chrome.storage
ahora muestran promesas.
Actualización de la política: Aplicación forzosa de la verificación en 2 pasos
Se actualizó la entrada de blog sobre la actualización de la política publicada el 29 de junio de 2021 para corregir el cronograma de implementación de la Verificación en dos pasos.
Chrome 94: Se realizaron cambios en el conjunto de reglas estáticas de solicitudes de red declarativas
chrome.declarativeNetRequest
ahora admite especificar hasta 50 conjuntos de reglas estáticos (MAX_NUMBER_OF_STATIC_RULESETS) y habilitar hasta 10 conjuntos de reglas (MAX_NUMBER_OF_ENABLED_STATIC_RULESETS) a la vez.
Chrome 93: Compatibilidad con el aislamiento de origen cruzado
Ahora, las extensiones de Manifest V2 y Manifest V3 pueden habilitar el aislamiento de origen cruzado. Esta función limita los recursos entre orígenes que pueden cargar las páginas de una extensión y habilita el uso de funciones de plataforma web de bajo nivel, como SharedArrayBuffer
. A partir de Chrome 95, se requerirá la habilitación.
Actualización de políticas: Se actualizaron las políticas del programa para desarrolladores
Se actualizaron las Políticas del programa para desarrolladores de Chrome Web Store con aclaraciones sobre las tácticas de instalación engañosas, el spam y las políticas de contenido repetitivo. Esta actualización también incluye un nuevo requisito de verificación en dos pasos para publicar en Chrome Web Store. Lee la entrada de blog para obtener más información.
Entrada de blog: Acciones de extensión en Manifest V3
Las extensiones de Chrome tenían las APIs de chrome.browserAction
y chrome.pageActions
durante años, pero Manifest V3 reemplazó ambas por una API genérica de chrome.actions
. En esta
entrada, se explora el historial de estas APIs y lo que cambió en Manifest V3. Lee la entrada.
Entrada de blog: Presentamos chrome.scripting
La API de chrome.scripting
es una nueva API de Manifest V3 enfocada en la escritura de secuencias de comandos. En esta publicación, analizamos las motivaciones de este cambio y analizamos con mayor detalle sus nuevas funciones. Lee la entrada.
Chrome 92: Compatibilidad con el trabajador de servicio del módulo
Chrome ahora admite módulos de JavaScript en los trabajadores del servicio. Para especificar un módulo en tu manifiesto, haz lo siguiente:
"background": {
"service_worker": "script.js",
"type": "module"
}
Esto carga la secuencia de comandos del trabajador como un módulo de ES, lo que te permite usar la palabra clave import
en la secuencia de comandos del trabajador para importar otros módulos.
Chrome 91: chrome.action.getUserSettings()
El nuevo método chrome.action.getUserSettings()
permite que las extensiones determinen si el usuario fijó la extensión en la barra de herramientas principal.
Chrome 90: chrome.scripting.removeCSS()
El nuevo método chrome.scripting.removeCSS()
permite que las extensiones quiten el CSS que se insertó anteriormente a través de chrome.scripting.insertCSS()
. Reemplaza chrome.tabs.removeCSS()
.
Chrome 90: Devuelve promesas de scripting.executeScript().
chrome.scripting.executeScript()
ahora admite mostrar promesas. Si el valor resultante de la ejecución de la secuencia de comandos es una promesa, Chrome
esperará a que se establezca y muestre su valor resultante.
Chrome 90: Los resultados de chrome.scripting.executeScript() incluyen frameId.
Los resultados que se muestran de chrome.scripting.executeScript()
ahora incluyen frameId.
La propiedad frameId
indica el fotograma del que proviene el resultado, lo que permite que las extensiones asocien fácilmente los resultados con los fotogramas individuales cuando se insertan en varios fotogramas.
Chrome 89: Nueva API para administrar grupos de pestañas
La nueva API de chrome.tabGroups
y las nuevas funciones de chrome.tabs
permiten que las extensiones lean y manipulen grupos de pestañas.
Requiere Manifest V3.
Chrome 89: Permisos personalizables para recursos accesibles a través de la Web
Las definiciones de recursos accesibles a través de la Web en el manifiesto V3 cambiaron para permitir que las extensiones restrinjan el acceso a los recursos según el origen del solicitante o el ID de la extensión.
Entrada de blog: Extension Manifest Converter
El equipo de Extensiones de Chrome lanzó el código abierto de "Extension Manifest Converter", una herramienta de Python que automatiza algunos de los aspectos mecánicos de la conversión de extensiones a Manifest V3. Consulta la entrada de blog del anuncio y obténla desde GitHub.
Chrome 88: Disponibilidad general de Manifest V3
Manifest V3 es una actualización importante de la plataforma de extensiones. Consulta Descripción general de Manifest V3 para obtener un resumen de las funciones nuevas y modificadas. Por el momento, las extensiones pueden seguir usando Manifest V2, pero se eliminará gradualmente en un futuro cercano. Te recomendamos que uses Manifest V3 para las extensiones nuevas y que comiences a migrar las extensiones existentes a Manifest V3 lo antes posible.