Path: blob/main/files/en-us/mozilla/add-ons/webextensions/api/bookmarks/search/index.md
6578 views
------{{AddonSidebar()}}
The bookmarks.search() function searches for bookmark tree nodes matching the given query.
This function throws an exception if any of the input parameters are invalid or are not of an appropriate type; look in the console for the error message. The exceptions don't have error IDs, and the messages themselves may change, so don't write code that tries to interpret them.
This is an asynchronous function that returns a Promise.
Syntax
Parameters
query: A {{jsxref("string")}} or {{jsxref("object")}} describing the query to perform.
If
queryis a string, it consists of zero or more space-delimited search terms. Each search term matches if it is a substring in the bookmark's URL or title. Matching is case-insensitive. For a bookmark to match the query, all the query's search terms must be matched.If
queryis an object, it consists of zero or more of 3 properties:query,title, andurl, which are described below. For a bookmark to match the query, all the properties' terms must be matched.query{{optional_inline}}: A {{jsxref("string")}} specifying one or more terms to match against; the format is identical to the string form of the
queryparameter. If this isn't a string, an exception is thrown.
url{{optional_inline}}: A {{jsxref("string")}} that must exactly match the bookmark's URL. Matching is case-insensitive, and trailing slashes are ignored.
If you pass an invalid URL, the function will throw an exception.
title{{optional_inline}}: A {{jsxref("string")}} that must exactly match the bookmark tree node's title. Matching is case-sensitive.
Return value
A Promise that will be fulfilled with an array of {{WebExtAPIRef('bookmarks.BookmarkTreeNode')}} objects, each representing a single matching bookmark tree node. Results are returned in the order that the nodes were created. The array is empty if no results were found.
The BookmarkTreeNodes—even nodes of the "folder" type—returned by bookmarks.search() are missing the children property. To get a complete BookmarkTreeNode use bookmarks.getSubTree().
Example
This example logs the IDs of all bookmarks:
This example looks to see if the currently active tab is bookmarked:
{{WebExtExamples}}
Browser compatibility
{{Compat}}
Note: This API is based on Chromium's
chrome.bookmarksAPI. This documentation is derived frombookmarks.jsonin the Chromium code.