chrome.bookmarks

说明

使用 chrome.bookmarks API 创建、整理和以其他方式处理书签。另请参阅替换页面,您可以使用该页面创建自定义书签管理器页面。

点击星形图标即可添加书签
点击星形图标可添加书签。

权限

bookmarks

您必须在扩展程序清单中声明“书签”权限,才能使用 Bookmarks API。例如:

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

概念和用法

对象和属性

书签以树状结构进行整理,其中树中的每个节点都是一个书签或文件夹(有时称为)。树中的每个节点都由 bookmarks.BookmarkTreeNode 对象表示。

BookmarkTreeNode 属性在整个 chrome.bookmarks API 中均可使用。例如,调用 bookmarks.create 时,您需要传入新节点的父节点 (parentId),以及可选的节点的 indextitleurl 属性。如需了解节点可以具有的属性,请参阅 bookmarks.BookmarkTreeNode

示例

以下代码会创建一个标题为“扩展程序书签”的文件夹。create() 的第一个参数用于指定新文件夹的属性。第二个实参用于定义在创建文件夹后要执行的函数。

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

以下代码段会创建一个指向扩展程序开发者文档的书签。由于创建书签失败不会造成任何不良后果,因此此代码不必定义回调函数。

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

如需试用此 API,请从 chrome-extension-samples 代码库安装 Bookmarks API 示例

类型

BookmarkTreeNode

书签树中的节点(书签或文件夹)。子节点在其父级文件夹中会按顺序排列。

属性

  • 孩子

    此节点的子节点的有序列表。

  • dateAdded

    number 可选

    此节点的创建时间(以从公元纪年开始计算的毫秒数表示 [new Date(dateAdded)])。

  • dateGroupModified

    编号(可选)

    此文件夹上次更改内容的时间(以自纪元以来的毫秒数表示)。

  • dateLastUsed

    编号(可选)

    Chrome 114 及更高版本

    此节点上次打开的时间(以自纪元以来经过的毫秒数表示)。未为文件夹设置。

  • folderType

    FolderType(文件夹类型)可选

    待处理

    如果存在,则表示这是由浏览器添加的文件夹,用户或扩展程序无法对其进行修改。如果此节点未设置 unmodifiable 属性,则可能会修改子节点。如果节点可由用户和扩展程序修改,则省略此属性(默认)。

    每种文件夹类型可能有 0 个、1 个或多个节点。文件夹可以通过浏览器添加或移除,但不能通过扩展程序 API 添加或移除。

  • id

    字符串

    节点的唯一标识符。这些 ID 在当前个人资料中是唯一的,即使浏览器重启后,它们也仍然有效。

  • 索引

    编号(可选)

    此节点在其父级文件夹中的编号(从 0 开始)。

  • parentId

    字符串(选填)

    父级文件夹的 id。对于根节点,请省略此属性。

  • 正在同步

    布尔值

    待处理

    此节点是否由浏览器与用户的远程账号存储空间同步。这可用于区分同一 FolderType 的账号版本和仅限本地版本。现有节点的此属性的值可能会发生变化,例如,因用户操作而发生变化。

    注意:这反映了节点是否保存到浏览器的内置账号提供程序。即使此值为 false,节点也有可能通过第三方进行同步。

    对于受管理节点(将 unmodifiable 设置为 true 的节点),此属性始终为 false

  • title

    字符串

    为节点显示的文本。

  • 不可修改

    “managed”
     可选

    指明此节点不可修改的原因。managed 值表示此节点是由系统管理员或受监督用户的监护人配置的。如果节点可由用户和扩展程序修改,则省略此属性(默认)。

  • 网址

    字符串(选填)

    用户点击书签后转到的网址。文件夹会省略此字段。

BookmarkTreeNodeUnmodifiable

Chrome 44 及更高版本

指明此节点不可修改的原因。managed 值表示此节点由系统管理员配置。如果节点可由用户和扩展程序修改,则省略此属性(默认)。

“managed”

CreateDetails

传递给 create() 函数的对象。

属性

  • 索引

    编号(可选)

  • parentId

    字符串(选填)

    默认为“其他书签”文件夹。

  • title

    字符串(选填)

  • 网址

    字符串(选填)

FolderType

待处理

指示文件夹的类型。

  • bookmarks-bar:内容显示在浏览器窗口顶部的文件夹
  • 其他:显示在所有平台的完整书签列表中的书签
  • mobile:通常在用户的移动设备上可用的书签,但可通过扩展程序或在书签管理器中修改
  • 受管理:如果系统管理员或受监督用户的监护人配置了书签,则系统可能会显示一个顶级文件夹。

枚举

"bookmarks-bar"

“other”

"mobile"

“managed”

属性

MAX_SUSTAINED_WRITE_OPERATIONS_PER_MINUTE

已废弃

书签写入操作不再受 Chrome 限制。

1000000

MAX_WRITE_OPERATIONS_PER_HOUR

已废弃

书签写入操作不再受 Chrome 限制。

1000000

方法

create()

prometido
chrome.bookmarks.create(
  bookmark: CreateDetails,
  callback?: function,
)

在指定的 parentId 下创建书签或文件夹。如果网址为 null 或缺失,则为文件夹。

参数

返回

  • Chrome 90 及更高版本

    清单 V3 及更高版本支持 Promise,但为了实现向后兼容性,我们提供了回调。您不能在同一函数调用中同时使用这两种方法。promise 的解析结果与传递给回调的类型相同。

get()

prometido
chrome.bookmarks.get(
  idOrIdList: string | [string, ...string[]],
  callback?: function,
)

检索指定的 BookmarkTreeNode。

参数

  • idOrIdList

    string | [string, ...string[]]

    一个字符串值 ID,或一个字符串值 ID 数组

  • callback

    函数(可选)

    callback 参数如下所示:

    (results: BookmarkTreeNode[]) => void

返回

  • Promise<BookmarkTreeNode[]>

    Chrome 90 及更高版本

    清单 V3 及更高版本支持 Promise,但为了实现向后兼容性,我们提供了回调。您不能在同一函数调用中同时使用这两种方法。promise 的解析结果与传递给回调的类型相同。

getChildren()

prometido
chrome.bookmarks.getChildren(
  id: string,
  callback?: function,
)

检索指定 BookmarkTreeNode ID 的子项。

参数

返回

  • Promise<BookmarkTreeNode[]>

    Chrome 90 及更高版本

    清单 V3 及更高版本支持 Promise,但为了实现向后兼容性,我们提供了回调。您不能在同一函数调用中同时使用这两种方法。promise 的解析结果与传递给回调的类型相同。

getRecent()

prometido
chrome.bookmarks.getRecent(
  numberOfItems: number,
  callback?: function,
)

检索最近添加的书签。

参数

  • numberOfItems

    数值

    需要返回的最大项数。

  • callback

    函数(可选)

    callback 参数如下所示:

    (results: BookmarkTreeNode[]) => void

返回

  • Promise<BookmarkTreeNode[]>

    Chrome 90 及更高版本

    清单 V3 及更高版本支持 Promise,但为了实现向后兼容性,我们提供了回调。您不能在同一函数调用中同时使用这两种方法。promise 的解析结果与传递给回调的类型相同。

getSubTree()

prometido
chrome.bookmarks.getSubTree(
  id: string,
  callback?: function,
)

检索从指定节点开始的部分书签层次结构。

参数

  • id

    字符串

    要检索的子树的根的 ID。

  • callback

    函数(可选)

    callback 参数如下所示:

    (results: BookmarkTreeNode[]) => void

返回

  • Promise<BookmarkTreeNode[]>

    Chrome 90 及更高版本

    清单 V3 及更高版本支持 Promise,但为了实现向后兼容性,我们提供了回调。您不能在同一函数调用中同时使用这两种方法。promise 的解析结果与传递给回调的类型相同。

getTree()

prometido
chrome.bookmarks.getTree(
  callback?: function,
)

检索整个“书签”层次结构。

参数

返回

  • Promise<BookmarkTreeNode[]>

    Chrome 90 及更高版本

    清单 V3 及更高版本支持 Promise,但为了实现向后兼容性,我们提供了回调。您不能在同一函数调用中同时使用这两种方法。promise 的解析结果与传递给回调的类型相同。

move()

prometido
chrome.bookmarks.move(
  id: string,
  destination: object,
  callback?: function,
)

将指定的 BookmarkTreeNode 移至所提供的位置。

参数

  • id

    字符串

  • 目标账号

    对象

    • 索引

      编号(可选)

    • parentId

      字符串(选填)

  • callback

    函数(可选)

    callback 参数如下所示:

    (result: BookmarkTreeNode) => void

返回

  • Chrome 90 及更高版本

    清单 V3 及更高版本支持 Promise,但为了实现向后兼容性,我们提供了回调。您不能在同一函数调用中同时使用这两种方法。promise 的解析结果与传递给回调的类型相同。

remove()

prometido
chrome.bookmarks.remove(
  id: string,
  callback?: function,
)

移除书签或空白书签文件夹。

参数

  • id

    字符串

  • callback

    函数(可选)

    callback 参数如下所示:

    () => void

返回

  • Promise<void>

    Chrome 90 及更高版本

    清单 V3 及更高版本支持 Promise,但为了实现向后兼容性,我们提供了回调。您不能在同一函数调用中同时使用这两种方法。promise 的解析结果与传递给回调的类型相同。

removeTree()

prometido
chrome.bookmarks.removeTree(
  id: string,
  callback?: function,
)

递归移除书签文件夹。

参数

  • id

    字符串

  • callback

    函数(可选)

    callback 参数如下所示:

    () => void

返回

  • Promise<void>

    Chrome 90 及更高版本

    清单 V3 及更高版本支持 Promise,但为了实现向后兼容性,我们提供了回调。您不能在同一函数调用中同时使用这两种方法。promise 的解析结果与传递给回调的类型相同。

prometido
chrome.bookmarks.search(
  query: string | object,
  callback?: function,
)

搜索与给定查询匹配的 BookmarkTreeNode。使用对象指定的查询会生成与所有指定属性匹配的 BookmarkTreeNode。

参数

  • 查询

    字符串 | 对象

    一个字符串,其中包含要与书签网址和标题进行匹配的字词和带引号的短语,或者一个对象。如果是对象,则可以指定 queryurltitle 属性,系统会生成与所有指定属性匹配的书签。

    • 查询

      字符串(选填)

      一串字词和引号括起来的短语,用于与书签网址和标题进行匹配。

    • title

      字符串(选填)

      书签的标题;完全匹配。

    • 网址

      字符串(选填)

      书签的网址;完全匹配。请注意,文件夹没有网址。

  • callback

    函数(可选)

    callback 参数如下所示:

    (results: BookmarkTreeNode[]) => void

返回

  • Promise<BookmarkTreeNode[]>

    Chrome 90 及更高版本

    清单 V3 及更高版本支持 Promise,但为了实现向后兼容性,我们提供了回调。您不能在同一函数调用中同时使用这两种方法。promise 的解析结果与传递给回调的类型相同。

update()

prometido
chrome.bookmarks.update(
  id: string,
  changes: object,
  callback?: function,
)

更新书签或文件夹的属性。请仅指定您要更改的属性;未指定的属性将保持不变。注意:目前,仅支持“title”和“url”。

参数

  • id

    字符串

  • 更改

    对象

    • title

      字符串(选填)

    • 网址

      字符串(选填)

  • callback

    函数(可选)

    callback 参数如下所示:

    (result: BookmarkTreeNode) => void

返回

  • Chrome 90 及更高版本

    清单 V3 及更高版本支持 Promise,但为了实现向后兼容性,我们提供了回调。您不能在同一函数调用中同时使用这两种方法。promise 的解析结果与传递给回调的类型相同。

事件

onChanged

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

在书签或文件夹发生变化时触发。注意:目前,只有标题和网址更改会触发此操作。

参数

  • callback

    函数

    callback 参数如下所示:

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

    • id

      字符串

    • changeInfo

      对象

      • title

        字符串

      • 网址

        字符串(选填)

onChildrenReordered

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

当文件夹的子项因界面中的排序而更改其顺序时触发。此方法不会因 move() 而被调用。

参数

  • callback

    函数

    callback 参数如下所示:

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

    • id

      字符串

    • reorderInfo

      对象

      • childIds

        字符串[]

onCreated

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

在创建书签或文件夹时触发。

参数

onImportBegan

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

在开始书签导入会话时触发。在 onImportEnded 触发之前,开销较大的观察器应忽略 onCreated 更新。观察器仍应立即处理其他通知。

参数

  • callback

    函数

    callback 参数如下所示:

    () => void

onImportEnded

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

在书签导入会话结束时触发。

参数

  • callback

    函数

    callback 参数如下所示:

    () => void

onMoved

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

当书签或文件夹移至其他父级文件夹时触发。

参数

  • callback

    函数

    callback 参数如下所示:

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

    • id

      字符串

    • moveInfo

      对象

      • 索引

        数值

      • oldIndex

        数值

      • oldParentId

        字符串

      • parentId

        字符串

onRemoved

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

在移除书签或文件夹时触发。递归移除文件夹时,系统会为该文件夹触发一次通知,而不会为其内容触发任何通知。

参数

  • callback

    函数

    callback 参数如下所示:

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

    • id

      字符串

    • removeInfo

      对象

      • 索引

        数值

      • Chrome 48 及更高版本
      • parentId

        字符串