chrome.bookmarks

Descripción

Usa la API de chrome.bookmarks para crear, organizar y manipular marcadores de otras formas. Consulta también Páginas de reemplazo, que puedes usar para crear una página personalizada del Administrador de marcadores.

Cuando haces clic en la estrella, se agrega un marcador
Si haces clic en la estrella, se agregará un favorito.

Permisos

bookmarks

Debes declarar el permiso "bookmarks" en el manifiesto de la extensión para usar la API de Bookmarks. Por ejemplo:

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

Conceptos y uso

Objetos y propiedades

Los marcadores se organizan en un árbol, en el que cada nodo es un marcador o una carpeta (a veces, se denomina grupo). Cada nodo del árbol está representado por un objeto bookmarks.BookmarkTreeNode.

Las propiedades de BookmarkTreeNode se usan en toda la API de chrome.bookmarks. Por ejemplo, cuando llamas a bookmarks.create, pasas el elemento superior del nodo nuevo (parentId) y, de manera opcional, las propiedades index, title y url del nodo. Consulta bookmarks.BookmarkTreeNode para obtener información sobre las propiedades que puede tener un nodo.

Ejemplos

El siguiente código crea una carpeta con el título "Favoritos de la extensión". El primer argumento de create() especifica las propiedades de la carpeta nueva. El segundo argumento define una función que se ejecutará después de que se cree la carpeta.

chrome.bookmarks.create(
  {'parentId': bookmarkBar.id, 'title': 'Extension bookmarks'},
  function(newFolder) {
    console.log("added folder: " + newFolder.title);
  },
);

El siguiente fragmento crea un marcador que apunta a la documentación para desarrolladores de extensiones. Como no sucederá nada malo si falla la creación del marcador, este código no se molesta en definir una función de devolución de llamada.

chrome.bookmarks.create({
  'parentId': extensionsFolderId,
  'title': 'Extensions doc',
  'url': 'https://developer.chrome.com/docs/extensions',
});

Para probar esta API, instala el ejemplo de la API de Bookmarks desde el repositorio de chrome-extension-samples.

Tipos

BookmarkTreeNode

Es un nodo (ya sea un favorito o una carpeta) en el árbol de favoritos. Los nodos secundarios se ordenan dentro de su carpeta principal.

Propiedades

  • niños

    BookmarkTreeNode[] opcional

    Es una lista ordenada de los elementos secundarios de este nodo.

  • dateAdded

    número opcional

    Fecha y hora en que se creó este nodo, en milisegundos desde la época (new Date(dateAdded)).

  • dateGroupModified

    número opcional

    Fecha y hora en que se modificó el contenido de esta carpeta por última vez, en milisegundos desde la época.

  • dateLastUsed

    número opcional

    Chrome 114 y versiones posteriores

    Fecha y hora en que se abrió este nodo por última vez, en milisegundos desde el ciclo de entrenamiento. No se establece para las carpetas.

  • folderType

    FolderType opcional

    Chrome 134 y versiones posteriores

    Si está presente, es una carpeta que agrega el navegador y que no puede modificar el usuario ni la extensión. Se pueden modificar los nodos secundarios si este nodo no tiene establecida la propiedad unmodifiable. Se omite si el usuario y la extensión pueden modificar el nodo (opción predeterminada).

    Puede haber cero, uno o varios nodos de cada tipo de carpeta. El navegador puede agregar o quitar una carpeta, pero no a través de la API de extensiones.

  • id

    string

    Es el identificador único del nodo. Los IDs son únicos dentro del perfil actual y siguen siendo válidos incluso después de que se reinicia el navegador.

  • índice

    número opcional

    Es la posición basada en 0 de este nodo dentro de su carpeta principal.

  • parentId

    cadena opcional

    Es el id de la carpeta superior. Se omite para el nodo raíz.

  • sincronizando

    booleano

    Chrome 134 y versiones posteriores

    Indica si el navegador sincronizó este nodo con el almacenamiento remoto de la cuenta del usuario. Se puede usar para distinguir entre las versiones de la misma FolderType que son solo locales y las que son de la cuenta. El valor de esta propiedad puede cambiar para un nodo existente, por ejemplo, como resultado de una acción del usuario.

    Nota: Esto refleja si el nodo se guarda en el proveedor de cuentas integrado del navegador. Es posible que un nodo se pueda sincronizar a través de un tercero, incluso si este valor es falso.

    Para los nodos administrados (nodos en los que unmodifiable está establecido en true), esta propiedad siempre será false.

  • título

    string

    Es el texto que se muestra para el nodo.

  • inmodificable

    "managed"
     opcional

    Indica el motivo por el que este nodo no se puede modificar. El valor managed indica que el administrador del sistema o el tutor de un usuario supervisado configuraron este nodo. Se omite si el usuario y la extensión pueden modificar el nodo (opción predeterminada).

  • url

    cadena opcional

    Es la URL a la que se navega cuando un usuario hace clic en el marcador. Se omite para las carpetas.

BookmarkTreeNodeUnmodifiable

Chrome 44 y versiones posteriores

Indica el motivo por el que este nodo no se puede modificar. El valor managed indica que el administrador del sistema configuró este nodo. Se omite si el usuario y la extensión pueden modificar el nodo (opción predeterminada).

Valor

"managed"

CreateDetails

Objeto que se pasó a la función create().

Propiedades

  • índice

    número opcional

  • parentId

    cadena opcional

    La configuración predeterminada es la carpeta Otros favoritos.

  • título

    cadena opcional

  • url

    cadena opcional

FolderType

Chrome 134 y versiones posteriores

Indica el tipo de carpeta.

Enum

"bookmarks-bar"
Es la carpeta cuyo contenido se muestra en la parte superior de la ventana del navegador.

"other"
Favoritos que se muestran en la lista completa de favoritos en todas las plataformas.

"mobile"
Los favoritos suelen estar disponibles en los dispositivos móviles del usuario, pero se pueden modificar con una extensión o en el administrador de favoritos.

"managed"
Es una carpeta de nivel superior que puede estar presente si el administrador del sistema o el custodio de un usuario supervisado configuraron marcadores.

Propiedades

MAX_SUSTAINED_WRITE_OPERATIONS_PER_MINUTE

Obsoleto

Chrome ya no limita las operaciones de escritura de favoritos.

Valor

1000000

MAX_WRITE_OPERATIONS_PER_HOUR

Obsoleto

Chrome ya no limita las operaciones de escritura de favoritos.

Valor

1000000

Métodos

create()

chrome.bookmarks.create(
  bookmark: CreateDetails,
)
: Promise<BookmarkTreeNode>

Crea un favorito o una carpeta en el elemento principal especificado por parentId. Si la URL es NULL o falta, será una carpeta.

Parámetros

Muestra

get()

chrome.bookmarks.get(
  idOrIdList: string | [string, ...string[]],
)
: Promise<BookmarkTreeNode[]>

Recupera los BookmarkTreeNode especificados.

Parámetros

  • idOrIdList

    cadena | [cadena, …cadena[]]

    Un solo ID con valor de cadena o un array de IDs con valor de cadena

Muestra

getChildren()

chrome.bookmarks.getChildren(
  id: string,
)
: Promise<BookmarkTreeNode[]>

Recupera los elementos secundarios del ID de BookmarkTreeNode especificado.

Parámetros

  • id

    string

Muestra

getRecent()

chrome.bookmarks.getRecent(
  numberOfItems: number,
)
: Promise<BookmarkTreeNode[]>

Recupera los favoritos agregados recientemente.

Parámetros

  • numberOfItems

    número

    La cantidad máxima de elementos que se mostrarán.

Muestra

getSubTree()

chrome.bookmarks.getSubTree(
  id: string,
)
: Promise<BookmarkTreeNode[]>

Recupera parte de la jerarquía de marcadores, comenzando en el nodo especificado.

Parámetros

  • id

    string

    Es el ID de la raíz del subárbol que se recuperará.

Muestra

getTree()

chrome.bookmarks.getTree(): Promise<BookmarkTreeNode[]>

Recupera toda la jerarquía de favoritos.

Muestra

move()

chrome.bookmarks.move(
  id: string,
  destination: object,
)
: Promise<BookmarkTreeNode>

Mueve el BookmarkTreeNode especificado a la ubicación proporcionada.

Parámetros

  • id

    string

  • destino

    objeto

    • índice

      número opcional

    • parentId

      cadena opcional

Muestra

remove()

chrome.bookmarks.remove(
  id: string,
)
: Promise<void>

Quita un marcador o una carpeta de marcadores vacía.

Parámetros

  • id

    string

Muestra

  • Promise<void>

    Chrome 90 y versiones posteriores

removeTree()

chrome.bookmarks.removeTree(
  id: string,
)
: Promise<void>

Quita de forma recursiva una carpeta de favoritos.

Parámetros

  • id

    string

Muestra

  • Promise<void>

    Chrome 90 y versiones posteriores
chrome.bookmarks.search(
  query: string | object,
)
: Promise<BookmarkTreeNode[]>

Busca los BookmarkTreeNodes que coincidan con la consulta proporcionada. Las consultas especificadas con un objeto producen BookmarkTreeNodes que coinciden con todas las propiedades especificadas.

Parámetros

  • consulta

    cadena | objeto

    Puede ser una cadena de palabras y frases entre comillas que coinciden con las URLs y los títulos de los marcadores, o bien un objeto. Si es un objeto, se pueden especificar las propiedades query, url y title, y se producirán marcadores que coincidan con todas las propiedades especificadas.

    • consulta

      cadena opcional

      Es una cadena de palabras y frases entre comillas que se comparan con los títulos y las URLs de los favoritos.

    • título

      cadena opcional

      Es el título del marcador, que coincide textualmente.

    • url

      cadena opcional

      Es la URL del favorito, que debe coincidir exactamente. Ten en cuenta que las carpetas no tienen URL.

Muestra

update()

chrome.bookmarks.update(
  id: string,
  changes: object,
)
: Promise<BookmarkTreeNode>

Actualiza las propiedades de un marcador o una carpeta. Especifica solo las propiedades que deseas cambiar. Las propiedades no especificadas no se modificarán. Nota: Actualmente, solo se admiten "title" y "url".

Parámetros

  • id

    string

  • Cambios

    objeto

    • título

      cadena opcional

    • url

      cadena opcional

Muestra

Eventos

onChanged

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

Se activa cuando cambia un marcador o una carpeta. Nota: Actualmente, solo los cambios en el título y la URL activan esta acción.

Parámetros

  • callback

    función

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

    (id: string, changeInfo: object) => void

    • id

      string

    • changeInfo

      objeto

      • título

        string

      • url

        cadena opcional

onChildrenReordered

chrome.bookmarks.onChildrenReordered.addListener(
  callback: function,
)

Se activa cuando los elementos secundarios de una carpeta cambian su orden debido a que este se ordena en la IU. No se llama como resultado de un move().

Parámetros

  • callback

    función

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

    (id: string, reorderInfo: object) => void

    • id

      string

    • reorderInfo

      objeto

      • childIds

        string[]

onCreated

chrome.bookmarks.onCreated.addListener(
  callback: function,
)

Se activa cuando se crea un favorito o una carpeta.

Parámetros

  • callback

    función

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

    (id: string, bookmark: BookmarkTreeNode) => void

onImportBegan

chrome.bookmarks.onImportBegan.addListener(
  callback: function,
)

Se activa cuando se inicia una sesión de importación de marcadores. Los observadores costosos deben ignorar las actualizaciones de onCreated hasta que se active onImportEnded. Los observadores deben seguir controlando otras notificaciones de inmediato.

Parámetros

  • callback

    función

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

    () => void

onImportEnded

chrome.bookmarks.onImportEnded.addListener(
  callback: function,
)

Se activa cuando finaliza una sesión de importación de favoritos.

Parámetros

  • callback

    función

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

    () => void

onMoved

chrome.bookmarks.onMoved.addListener(
  callback: function,
)

Se activa cuando un favorito o una carpeta se mueve a otra carpeta superior.

Parámetros

  • callback

    función

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

    (id: string, moveInfo: object) => void

    • id

      string

    • moveInfo

      objeto

      • índice

        número

      • oldIndex

        número

      • oldParentId

        string

      • parentId

        string

onRemoved

chrome.bookmarks.onRemoved.addListener(
  callback: function,
)

Se activa cuando se quita un marcador o una carpeta. Cuando se quita una carpeta de forma recursiva, se activa una sola notificación para la carpeta y ninguna para su contenido.

Parámetros

  • callback

    función

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

    (id: string, removeInfo: object) => void

    • id

      string

    • removeInfo

      objeto

      • índice

        número

      • Chrome 48 y versiones posteriores
      • parentId

        string