תיאור
אפשר להשתמש ב-chrome.bookmarks
API כדי ליצור סימניות, לארגן אותן ולבצע פעולות אחרות. אפשר גם לעיין במאמר בנושא Override Pages, שמתאר איך ליצור דף מותאם אישית של ניהול הסימניות.

הרשאות
bookmarks
כדי להשתמש ב-Bookmarks API, צריך להצהיר על ההרשאה 'סימניות' במניפסט התוסף. לדוגמה:
{
"name": "My extension",
...
"permissions": [
"bookmarks"
],
...
}
מושגים ושימוש
אובייקטים ומאפיינים
הסימניות מאורגנות במבנה היררכי, שבו כל צומת בעץ הוא סימנייה או תיקייה (לפעמים נקרא קבוצה). כל צומת בעץ מיוצג על ידי אובייקט bookmarks.BookmarkTreeNode.
המאפיינים BookmarkTreeNode
נמצאים בשימוש בכל chrome.bookmarks
API. לדוגמה, כשקוראים ל-bookmarks.create, מעבירים את ההורה של הצומת החדש (parentId
), ואם רוצים, גם את המאפיינים index
, title
ו-url
של הצומת. מידע על המאפיינים שיכולים להיות לצומת זמין במאמר 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 הזה, מתקינים את הדוגמה ל-Bookmarks API ממאגר chrome-extension-samples.
סוגים
BookmarkTreeNode
צומת (סימנייה או תיקייה) בעץ הסימניות. הצמתים הצאצאים מסודרים בתיקיית האב שלהם.
מאפיינים
-
ילדים
BookmarkTreeNode[] אופציונלי
רשימה מסודרת של צאצאים של הצומת הזה.
-
dateAdded
מספר אופציונלי
הזמן שבו הצומת הזה נוצר, באלפיות השנייה מאז התקופה (
new Date(dateAdded)
). -
dateGroupModified
מספר אופציונלי
המועד שבו התוכן של התיקייה הזו השתנה לאחרונה, באלפיות השנייה מאז תקופת ה-epoch.
-
dateLastUsed
מספר אופציונלי
Chrome 114 ואילךהמועד האחרון שבו הצומת הזה נפתח, באלפיות השנייה מאז תקופת הזמן של המערכת. לא מוגדר לתיקיות.
-
folderType
FolderType אופציונלי
Chrome 134 ואילךאם היא קיימת, זו תיקייה שנוספת על ידי הדפדפן והמשתמש או התוסף לא יכולים לשנות אותה. אפשר לשנות צמתי צאצא אם לא מוגדר המאפיין
unmodifiable
בצומת הזה. ההגדרה מושמטת אם המשתמש והתוסף יכולים לשנות את הצומת (ברירת מחדל).יכול להיות שיהיו אפס, צומת אחד או כמה צמתים מכל סוג תיקייה. הדפדפן יכול להוסיף או להסיר תיקייה, אבל לא באמצעות ה-API של התוספים.
-
id [מזהה]
מחרוזת
המזהה הייחודי של הצומת. המזהים ייחודיים בפרופיל הנוכחי, והם נשארים בתוקף גם אחרי הפעלה מחדש של הדפדפן.
-
אינדקס
מספר אופציונלי
המיקום של הצומת הזה בתיקיית האב שלו, על בסיס 0.
-
parentId
מחרוזת אופציונלי
ה-
id
של תיקיית האב. הערך מושמט בצומת הבסיס. -
מתבצע סנכרון
בוליאני
Chrome 134 ואילךהאם הצומת הזה מסונכרן עם האחסון בחשבון המרוחק של המשתמש בדפדפן. אפשר להשתמש בזה כדי להבחין בין גרסאות של אותו
FolderType
שמוגדרות בחשבון לבין גרסאות שמוגדרות רק ברמה המקומית. הערך של המאפיין הזה עשוי להשתנות בצומת קיים, למשל כתוצאה מפעולת משתמש.הערה: הערך הזה משקף אם הצומת נשמר בספק החשבונות המובנה של הדפדפן. יכול להיות שצומת מסוים יסונכרן דרך צד שלישי, גם אם הערך הזה הוא false.
בצמתים מנוהלים (צמתים שבהם
unmodifiable
מוגדר כ-true
), המאפיין הזה תמיד יהיהfalse
. -
title
מחרוזת
הטקסט שמוצג לצומת.
-
לא ניתן לשינוי
'managed'
אופציונלימציין את הסיבה לכך שלא ניתן לשנות את הצומת הזה. הערך
managed
מציין שהצומת הזה הוגדר על ידי מנהל המערכת או על ידי האפוטרופוס של משתמש בפיקוח. ההגדרה מושמטת אם המשתמש והתוסף יכולים לשנות את הצומת (ברירת מחדל). -
כתובת אתר
מחרוזת אופציונלי
כתובת ה-URL שאליה המשתמש מנותב כשהוא לוחץ על הסימנייה. השדה לא רלוונטי לתיקיות.
BookmarkTreeNodeUnmodifiable
מציין את הסיבה לכך שלא ניתן לשנות את הצומת הזה. הערך managed
מציין שהצומת הזה הוגדר על ידי האדמין של המערכת. ההגדרה מושמטת אם המשתמש והתוסף יכולים לשנות את הצומת (ברירת מחדל).
ערך
"managed"
CreateDetails
האובייקט שמועבר לפונקציה create().
מאפיינים
-
אינדקס
מספר אופציונלי
-
parentId
מחרוזת אופציונלי
ברירת המחדל היא התיקייה 'סימניות אחרות'.
-
title
מחרוזת אופציונלי
-
כתובת אתר
מחרוזת אופציונלי
FolderType
מציין את סוג התיקייה.
Enum
bookmarks-bar
התיקייה שהתוכן שלה מוצג בחלק העליון של חלון הדפדפן.
'אחר'
סימניות שמוצגות ברשימה המלאה של הסימניות בכל הפלטפורמות.
mobile
סימניות זמינות בדרך כלל במכשירים הניידים של המשתמש, אבל אפשר לשנות אותן באמצעות תוסף או במנהל הסימניות.
מנוהל
תיקייה ברמה העליונה שיכולה להופיע אם אדמין המערכת או האפוטרופוס של משתמש בפיקוח הגדירו סימניות.
מאפיינים
MAX_SUSTAINED_WRITE_OPERATIONS_PER_MINUTE
פעולות כתיבה של סימניות כבר לא מוגבלות על ידי Chrome.
ערך
1000000
MAX_WRITE_OPERATIONS_PER_HOUR
פעולות כתיבה של סימניות כבר לא מוגבלות על ידי Chrome.
ערך
1000000
Methods
create()
chrome.bookmarks.create(
bookmark: CreateDetails,
): Promise<BookmarkTreeNode>
יוצר סימנייה או תיקייה מתחת ל-parentId שצוין. אם כתובת ה-URL היא NULL או חסרה, מדובר בתיקייה.
פרמטרים
-
סימנייה
החזרות
-
Promise<BookmarkTreeNode>
Chrome 90 ואילך
get()
chrome.bookmarks.get(
idOrIdList: string | [string, ...string[]],
): Promise<BookmarkTreeNode[]>
מאחזר את הצומת או הצמתים שצוינו בעץ הסימניות.
פרמטרים
-
idOrIdList
מחרוזת | [מחרוזת, ...מחרוזת[]]
מזהה יחיד עם ערך מחרוזת, או מערך של מזהים עם ערך מחרוזת
החזרות
-
Promise<BookmarkTreeNode[]>
Chrome 90 ואילך
getChildren()
chrome.bookmarks.getChildren(
id: string,
): Promise<BookmarkTreeNode[]>
מאחזר את רכיבי הצאצא של מזהה BookmarkTreeNode שצוין.
פרמטרים
-
id [מזהה]
מחרוזת
החזרות
-
Promise<BookmarkTreeNode[]>
Chrome 90 ואילך
getRecent()
chrome.bookmarks.getRecent(
numberOfItems: number,
): Promise<BookmarkTreeNode[]>
מאחזר את הסימניות שנוספו לאחרונה.
פרמטרים
-
numberOfItems
number
מספר הפריטים המקסימלי שיוחזרו.
החזרות
-
Promise<BookmarkTreeNode[]>
Chrome 90 ואילך
getSubTree()
chrome.bookmarks.getSubTree(
id: string,
): Promise<BookmarkTreeNode[]>
מאחזרת חלק מההיררכיה של הסימניות, החל מהצומת שצוין.
פרמטרים
-
id [מזהה]
מחרוזת
המזהה של שורש עץ המשנה שיש לאחזר.
החזרות
-
Promise<BookmarkTreeNode[]>
Chrome 90 ואילך
החזרות
-
Promise<BookmarkTreeNode[]>
Chrome 90 ואילך
move()
chrome.bookmarks.move(
id: string,
destination: object,
): Promise<BookmarkTreeNode>
מעביר את BookmarkTreeNode שצוין למיקום שסופק.
פרמטרים
-
id [מזהה]
מחרוזת
-
destination
אובייקט
-
אינדקס
מספר אופציונלי
-
parentId
מחרוזת אופציונלי
-
החזרות
-
Promise<BookmarkTreeNode>
Chrome 90 ואילך
remove()
chrome.bookmarks.remove(
id: string,
): Promise<void>
מסיר סימנייה או תיקיית סימניות ריקה.
פרמטרים
-
id [מזהה]
מחרוזת
החזרות
-
Promise<void>
Chrome 90 ואילך
removeTree()
chrome.bookmarks.removeTree(
id: string,
): Promise<void>
מסיר תיקיית סימניות באופן רקורסיבי.
פרמטרים
-
id [מזהה]
מחרוזת
החזרות
-
Promise<void>
Chrome 90 ואילך
search()
chrome.bookmarks.search(
query: string | object,
): Promise<BookmarkTreeNode[]>
חיפוש של BookmarkTreeNodes שתואמים לשאילתה הנתונה. שאילתות שמצוינות באמצעות אובייקט יוצרות BookmarkTreeNodes שתואמים לכל המאפיינים שצוינו.
פרמטרים
-
שאילתה
string | object
מחרוזת של מילים וביטויים במירכאות שמושוות לכתובות URL ולשמות של סימניות, או אובייקט. אם מדובר באובייקט, אפשר לציין את המאפיינים
query
,url
ו-title
, ויוצגו סימניות שתואמות לכל המאפיינים שצוינו.-
שאילתה
מחרוזת אופציונלי
מחרוזת של מילים וביטויים במירכאות שמושוות לכתובות URL ולכותרות של סימניות.
-
title
מחרוזת אופציונלי
השם של הסימנייה, זהה בדיוק.
-
כתובת אתר
מחרוזת אופציונלי
כתובת ה-URL של הסימנייה. ההתאמה היא מילולית. לתשומת ליבכם, לתיקיות אין כתובת URL.
-
החזרות
-
Promise<BookmarkTreeNode[]>
Chrome 90 ואילך
update()
chrome.bookmarks.update(
id: string,
changes: object,
): Promise<BookmarkTreeNode>
עדכון המאפיינים של סימנייה או תיקייה. מציינים רק את המאפיינים שרוצים לשנות. מאפיינים שלא צוינו יישארו ללא שינוי. הערה: נכון לעכשיו, המערכת תומכת רק במאפיינים title (שם) ו-url (כתובת URL).
פרמטרים
-
id [מזהה]
מחרוזת
-
שינויים
אובייקט
-
title
מחרוזת אופציונלי
-
כתובת אתר
מחרוזת אופציונלי
-
החזרות
-
Promise<BookmarkTreeNode>
Chrome 90 ואילך
אירועים
onChanged
chrome.bookmarks.onChanged.addListener(
callback: function,
)
מופעל כשסימנייה או תיקייה משתנות. הערה: נכון לעכשיו, רק שינויים בשם ובכתובת ה-URL מפעילים את התהליך הזה.
פרמטרים
-
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
string[]
-
-
onCreated
chrome.bookmarks.onCreated.addListener(
callback: function,
)
מופעל כשנוצרת סימנייה או תיקייה.
פרמטרים
-
callback
פונקציה
הפרמטר
callback
נראה כך:(id: string, bookmark: BookmarkTreeNode) => void
-
id [מזהה]
מחרוזת
-
סימנייה
-
onImportBegan
chrome.bookmarks.onImportBegan.addListener(
callback: function,
)
מופעל כשמתחיל סשן ייבוא של סימניות. במקרה של observers יקרים, צריך להתעלם מעדכוני onCreated עד להפעלת onImportEnded. המשקיפים צריכים להמשיך לטפל בהתראות אחרות באופן מיידי.
פרמטרים
-
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
אובייקט
-
אינדקס
number
-
oldIndex
number
-
oldParentId
מחרוזת
-
parentId
מחרוזת
-
-
onRemoved
chrome.bookmarks.onRemoved.addListener(
callback: function,
)
מופעל כשמסירים סימנייה או תיקייה. כשמסירים תיקייה באופן רקורסיבי, נשלחת התראה אחת לגבי התיקייה, ולא נשלחות התראות לגבי התוכן שלה.
פרמטרים
-
callback
פונקציה
הפרמטר
callback
נראה כך:(id: string, removeInfo: object) => void
-
id [מזהה]
מחרוזת
-
removeInfo
אובייקט
-
אינדקס
number
-
צומתChrome 48 ואילך
-
parentId
מחרוזת
-
-