chrome.bookmarks

यह अनुमति चेतावनी ट्रिगर करती है.

कंपनी का ब्यौरा

बुकमार्क बनाने, व्यवस्थित करने, और उनमें अन्य तरीके से बदलाव करने के लिए, chrome.bookmarks API का इस्तेमाल करें. पेजों में बदलाव करें भी देखें. इसका इस्तेमाल, कस्टम बुकमार्क मैनेजर पेज बनाने के लिए किया जा सकता है.

अनुमतियां

bookmarks

तारा क्लिक करने से एक बुकमार्क जुड़ जाता है

मेनिफ़ेस्ट

बुकमार्क एपीआई का इस्तेमाल करने के लिए, आपको एक्सटेंशन मेनिफ़ेस्ट में "बुकमार्क" अनुमति के बारे में एलान करना होगा. उदाहरण के लिए:

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

ऑब्जेक्ट और प्रॉपर्टी

बुकमार्क, ट्री में व्यवस्थित किए जाते हैं, जहां ट्री में मौजूद हर नोड कोई बुकमार्क या फ़ोल्डर होता है (कभी-कभी इसे ग्रुप भी कहा जाता है). ट्री के हर नोड को bookmarks.BookmarkTreeNode ऑब्जेक्ट से दिखाया जाता है.

BookmarkTreeNode प्रॉपर्टी का इस्तेमाल, chrome.bookmarks एपीआई में किया जाता है. उदाहरण के लिए, 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',
});

इस एपीआई को आज़माने के लिए, chrome-extension-sample डेटा स्टोर करने की जगह से Bookmarks API उदाहरण इंस्टॉल करें.

टाइप

BookmarkTreeNode

बुकमार्क ट्री में कोई नोड (या तो बुकमार्क या फ़ोल्डर). चाइल्ड नोड उनके पैरंट फ़ोल्डर में क्रम से लगाए जाते हैं.

प्रॉपर्टी

  • बच्चे

    BookmarkTreeNode[] ज़रूरी नहीं

    इस नोड के बच्चों की क्रम में लगाई गई सूची.

  • dateAdded

    नंबर ज़रूरी नहीं

    जब यह नोड बनाया गया था, तो epoch (new Date(dateAdded)) के बाद से मिलीसेकंड में.

  • dateGroupModified

    नंबर ज़रूरी नहीं

    जब इस फ़ोल्डर का कॉन्टेंट पिछली बार बदला था, तो epoch के बाद से मिलीसेकंड में.

  • dateLastUsed

    नंबर ज़रूरी नहीं

    Chrome 114 और इसके बाद के वर्शन

    जब इस नोड को आखिरी बार खोला गया था, तो epoch के बाद से मिलीसेकंड में. फ़ोल्डर के लिए सेट नहीं है.

  • आईडी

    स्ट्रिंग

    नोड के लिए यूनीक आइडेंटिफ़ायर. मौजूदा प्रोफ़ाइल में आईडी यूनीक होते हैं. साथ ही, ब्राउज़र के रीस्टार्ट होने के बाद भी वे मान्य रहते हैं.

  • इंडेक्स

    नंबर ज़रूरी नहीं

    इस नोड के पैरंट फ़ोल्डर में इसकी 0 पर आधारित जगह.

  • parentId

    स्ट्रिंग ज़रूरी नहीं

    पैरंट फ़ोल्डर का id. रूट नोड के लिए हटाया गया.

  • title

    स्ट्रिंग

    नोड के लिए दिखाया गया टेक्स्ट.

  • बदलाव नहीं किया जा सकता

     ज़रूरी नहीं है

    यह बताता है कि इस नोड में बदलाव क्यों नहीं किया जा सकता. managed वैल्यू से पता चलता है कि इस नोड को सिस्टम एडमिन या निगरानी में रखे गए उपयोगकर्ता के ग्राहक ने कॉन्फ़िगर किया था. अगर नोड में उपयोगकर्ता और एक्सटेंशन (डिफ़ॉल्ट) बदलाव कर सकते हैं, तो इसे हटा दिया जाएगा.

  • यूआरएल

    स्ट्रिंग ज़रूरी नहीं

    वह यूआरएल जिस पर उपयोगकर्ता के बुकमार्क पर क्लिक करने पर पहुंचता है. फ़ोल्डर के लिए हटाया गया.

BookmarkTreeNodeUnmodifiable

Chrome 44 और इसके बाद के वर्शन

यह बताता है कि इस नोड में बदलाव क्यों नहीं किया जा सकता. managed मान से पता चलता है कि इस नोड को सिस्टम एडमिन ने कॉन्फ़िगर किया था. अगर नोड में उपयोगकर्ता और एक्सटेंशन (डिफ़ॉल्ट) बदलाव कर सकते हैं, तो इसे हटा दिया जाएगा.

वैल्यू

CreateDetails

ऑब्जेक्ट को create() फ़ंक्शन में पास किया गया.

प्रॉपर्टी

  • इंडेक्स

    नंबर ज़रूरी नहीं

  • parentId

    स्ट्रिंग ज़रूरी नहीं

    डिफ़ॉल्ट रूप से, अन्य बुकमार्क फ़ोल्डर होता है.

  • title

    स्ट्रिंग ज़रूरी नहीं

  • यूआरएल

    स्ट्रिंग ज़रूरी नहीं

प्रॉपर्टी

MAX_SUSTAINED_WRITE_OPERATIONS_PER_MINUTE

अब सेवा में नहीं है

अब Chrome में, बुकमार्क लिखने की सुविधा सीमित नहीं है.

वैल्यू

1000000

MAX_WRITE_OPERATIONS_PER_HOUR

अब सेवा में नहीं है

अब Chrome में, बुकमार्क लिखने की सुविधा सीमित नहीं है.

वैल्यू

1000000

तरीके

create()

वादा
chrome.bookmarks.create(
  bookmark: CreateDetails,
  callback?: function,
)

दिए गए पैरंट आईडी के तहत बुकमार्क या फ़ोल्डर बनाता है. अगर यूआरएल शून्य है या मौजूद नहीं है, तो यह एक फ़ोल्डर होगा.

पैरामीटर

  • बुकमार्क
  • कॉलबैक

    फ़ंक्शन ज़रूरी नहीं

    callback पैरामीटर ऐसा दिखता है:

    (result: BookmarkTreeNode) => void

लौटाए गए प्रॉडक्ट

  • Chrome 90 और इसके बाद के वर्शन

    प्रॉमिस सिर्फ़ मेनिफ़ेस्ट V3 और उसके बाद के वर्शन पर काम करता है. अन्य प्लैटफ़ॉर्म के लिए कॉलबैक का इस्तेमाल करना ज़रूरी है.

get()

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

बताए गए BookmarkTreeNode को वापस लाता है.

पैरामीटर

  • idOrIdList

    स्ट्रिंग | [स्ट्रिंग, ...स्ट्रिंग[]]

    स्ट्रिंग की वैल्यू वाला सिंगल आईडी या स्ट्रिंग वैल्यू वाले आईडी की कैटगरी

  • कॉलबैक

    फ़ंक्शन ज़रूरी नहीं

    callback पैरामीटर ऐसा दिखता है:

    (results: BookmarkTreeNode[]) => void

लौटाए गए प्रॉडक्ट

  • Promise<BookmarkTreeNode[]>

    Chrome 90 और इसके बाद के वर्शन

    प्रॉमिस सिर्फ़ मेनिफ़ेस्ट V3 और उसके बाद के वर्शन पर काम करता है. अन्य प्लैटफ़ॉर्म के लिए कॉलबैक का इस्तेमाल करना ज़रूरी है.

getChildren()

वादा
chrome.bookmarks.getChildren(
  id: string,
  callback?: function,
)

बताए गए BookmarkTreeNode आईडी के बच्चों को वापस लाता है.

पैरामीटर

  • आईडी

    स्ट्रिंग

  • कॉलबैक

    फ़ंक्शन ज़रूरी नहीं

    callback पैरामीटर ऐसा दिखता है:

    (results: BookmarkTreeNode[]) => void

लौटाए गए प्रॉडक्ट

  • Promise<BookmarkTreeNode[]>

    Chrome 90 और इसके बाद के वर्शन

    प्रॉमिस सिर्फ़ मेनिफ़ेस्ट V3 और उसके बाद के वर्शन पर काम करता है. अन्य प्लैटफ़ॉर्म के लिए कॉलबैक का इस्तेमाल करना ज़रूरी है.

getRecent()

वादा
chrome.bookmarks.getRecent(
  numberOfItems: number,
  callback?: function,
)

हाल ही में जोड़े गए बुकमार्क वापस लाता है.

पैरामीटर

  • numberOfItems

    नंबर

    लौटाए जाने वाले आइटम की ज़्यादा से ज़्यादा संख्या.

  • कॉलबैक

    फ़ंक्शन ज़रूरी नहीं

    callback पैरामीटर ऐसा दिखता है:

    (results: BookmarkTreeNode[]) => void

लौटाए गए प्रॉडक्ट

  • Promise<BookmarkTreeNode[]>

    Chrome 90 और इसके बाद के वर्शन

    प्रॉमिस सिर्फ़ मेनिफ़ेस्ट V3 और उसके बाद के वर्शन पर काम करता है. अन्य प्लैटफ़ॉर्म के लिए कॉलबैक का इस्तेमाल करना ज़रूरी है.

getSubTree()

वादा
chrome.bookmarks.getSubTree(
  id: string,
  callback?: function,
)

बताए गए नोड से शुरू करते हुए, बुकमार्क हैरारकी का हिस्सा फिर से लेता है.

पैरामीटर

  • आईडी

    स्ट्रिंग

    फिर से हासिल करने के लिए, सबट्री के रूट का आईडी.

  • कॉलबैक

    फ़ंक्शन ज़रूरी नहीं

    callback पैरामीटर ऐसा दिखता है:

    (results: BookmarkTreeNode[]) => void

लौटाए गए प्रॉडक्ट

  • Promise<BookmarkTreeNode[]>

    Chrome 90 और इसके बाद के वर्शन

    प्रॉमिस सिर्फ़ मेनिफ़ेस्ट V3 और उसके बाद के वर्शन पर काम करता है. अन्य प्लैटफ़ॉर्म के लिए कॉलबैक का इस्तेमाल करना ज़रूरी है.

getTree()

वादा
chrome.bookmarks.getTree(
  callback?: function,
)

बुकमार्क की पूरी हैरारकी फिर से लाता है.

पैरामीटर

  • कॉलबैक

    फ़ंक्शन ज़रूरी नहीं

    callback पैरामीटर ऐसा दिखता है:

    (results: BookmarkTreeNode[]) => void

लौटाए गए प्रॉडक्ट

  • Promise<BookmarkTreeNode[]>

    Chrome 90 और इसके बाद के वर्शन

    प्रॉमिस सिर्फ़ मेनिफ़ेस्ट V3 और उसके बाद के वर्शन पर काम करता है. अन्य प्लैटफ़ॉर्म के लिए कॉलबैक का इस्तेमाल करना ज़रूरी है.

move()

वादा
chrome.bookmarks.move(
  id: string,
  destination: object,
  callback?: function,
)

बताए गए BookmarkTreeNode को दी गई जगह पर ले जाता है.

पैरामीटर

  • आईडी

    स्ट्रिंग

  • डेस्टिनेशन

    ऑब्जेक्ट

    • इंडेक्स

      नंबर ज़रूरी नहीं

    • parentId

      स्ट्रिंग ज़रूरी नहीं

  • कॉलबैक

    फ़ंक्शन ज़रूरी नहीं

    callback पैरामीटर ऐसा दिखता है:

    (result: BookmarkTreeNode) => void

लौटाए गए प्रॉडक्ट

  • Chrome 90 और इसके बाद के वर्शन

    प्रॉमिस सिर्फ़ मेनिफ़ेस्ट V3 और उसके बाद के वर्शन पर काम करता है. अन्य प्लैटफ़ॉर्म के लिए कॉलबैक का इस्तेमाल करना ज़रूरी है.

remove()

वादा
chrome.bookmarks.remove(
  id: string,
  callback?: function,
)

बुकमार्क या खाली बुकमार्क फ़ोल्डर को हटाता है.

पैरामीटर

  • आईडी

    स्ट्रिंग

  • कॉलबैक

    फ़ंक्शन ज़रूरी नहीं

    callback पैरामीटर ऐसा दिखता है:

    () => void

लौटाए गए प्रॉडक्ट

  • Promise<void>

    Chrome 90 और इसके बाद के वर्शन

    प्रॉमिस सिर्फ़ मेनिफ़ेस्ट V3 और उसके बाद के वर्शन पर काम करता है. अन्य प्लैटफ़ॉर्म के लिए कॉलबैक का इस्तेमाल करना ज़रूरी है.

removeTree()

वादा
chrome.bookmarks.removeTree(
  id: string,
  callback?: function,
)

बुकमार्क फ़ोल्डर को बार-बार हटाता है.

पैरामीटर

  • आईडी

    स्ट्रिंग

  • कॉलबैक

    फ़ंक्शन ज़रूरी नहीं

    callback पैरामीटर ऐसा दिखता है:

    () => void

लौटाए गए प्रॉडक्ट

  • Promise<void>

    Chrome 90 और इसके बाद के वर्शन

    प्रॉमिस सिर्फ़ मेनिफ़ेस्ट V3 और उसके बाद के वर्शन पर काम करता है. अन्य प्लैटफ़ॉर्म के लिए कॉलबैक का इस्तेमाल करना ज़रूरी है.

वादा
chrome.bookmarks.search(
  query: string | object,
  callback?: function,
)

दी गई क्वेरी से मेल खाने वाले BookmarkTreeNodes को खोजा जाता है. किसी ऑब्जेक्ट के साथ तय की गई क्वेरी, सभी खास प्रॉपर्टी से मेल खाने वाले BookmarkTreeNodes जनरेट करती हैं.

पैरामीटर

  • query

    स्ट्रिंग | ऑब्जेक्ट

    शब्दों और कोट किए गए वाक्यांशों की ऐसी स्ट्रिंग जो बुकमार्क यूआरएल और टाइटल से मेल खाती हो या फिर किसी ऑब्जेक्ट से मेल खाती हो. अगर कोई ऑब्जेक्ट है, तो query, url, और title प्रॉपर्टी तय की जा सकती हैं. साथ ही, बताई गई सभी प्रॉपर्टी से मेल खाने वाले बुकमार्क बनाए जाएंगे.

    • query

      स्ट्रिंग ज़रूरी नहीं

      शब्दों और कोट किए हुए वाक्यांशों की ऐसी स्ट्रिंग जिनका मिलान बुकमार्क यूआरएल और टाइटल से किया जाता है.

    • title

      स्ट्रिंग ज़रूरी नहीं

      बुकमार्क का टाइटल; शब्द के हिसाब से शब्द से मेल खाता है.

    • यूआरएल

      स्ट्रिंग ज़रूरी नहीं

      बुकमार्क का यूआरएल; हर शब्द से मिलता-जुलता है. ध्यान दें कि फ़ोल्डर में कोई यूआरएल नहीं होता.

  • कॉलबैक

    फ़ंक्शन ज़रूरी नहीं

    callback पैरामीटर ऐसा दिखता है:

    (results: BookmarkTreeNode[]) => void

लौटाए गए प्रॉडक्ट

  • Promise<BookmarkTreeNode[]>

    Chrome 90 और इसके बाद के वर्शन

    प्रॉमिस सिर्फ़ मेनिफ़ेस्ट V3 और उसके बाद के वर्शन पर काम करता है. अन्य प्लैटफ़ॉर्म के लिए कॉलबैक का इस्तेमाल करना ज़रूरी है.

update()

वादा
chrome.bookmarks.update(
  id: string,
  changes: object,
  callback?: function,
)

किसी बुकमार्क या फ़ोल्डर की प्रॉपर्टी अपडेट करता है. सिर्फ़ उन प्रॉपर्टी की जानकारी दें जिनमें बदलाव करना है. जो प्रॉपर्टी नहीं बताई गई हैं उनमें कोई बदलाव नहीं होगा. ध्यान दें: फ़िलहाल, सिर्फ़ 'टाइटल' और 'यूआरएल' का इस्तेमाल किया जा सकता है.

पैरामीटर

  • आईडी

    स्ट्रिंग

  • बदलाव

    ऑब्जेक्ट

    • title

      स्ट्रिंग ज़रूरी नहीं

    • यूआरएल

      स्ट्रिंग ज़रूरी नहीं

  • कॉलबैक

    फ़ंक्शन ज़रूरी नहीं

    callback पैरामीटर ऐसा दिखता है:

    (result: BookmarkTreeNode) => void

लौटाए गए प्रॉडक्ट

  • Chrome 90 और इसके बाद के वर्शन

    प्रॉमिस सिर्फ़ मेनिफ़ेस्ट V3 और उसके बाद के वर्शन पर काम करता है. अन्य प्लैटफ़ॉर्म के लिए कॉलबैक का इस्तेमाल करना ज़रूरी है.

इवेंट

onChanged

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

बुकमार्क या फ़ोल्डर बदलने पर सक्रिय होता है. ध्यान दें: फ़िलहाल, यह सुविधा सिर्फ़ टाइटल और यूआरएल में हुए बदलावों को ट्रिगर करती है.

पैरामीटर

  • कॉलबैक

    function

    callback पैरामीटर ऐसा दिखता है:

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

    • आईडी

      स्ट्रिंग

    • changeInfo

      ऑब्जेक्ट

      • title

        स्ट्रिंग

      • यूआरएल

        स्ट्रिंग ज़रूरी नहीं

onChildrenReordered

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

तब सक्रिय होता है, जब यूज़र इंटरफ़ेस (यूआई) में क्रम से लगाए जाने की वजह से फ़ोल्डर के बच्चों ने अपना क्रम बदल दिया हो. इसे माइग्रेट() के नतीजे के तौर पर नहीं कहा जाता.

पैरामीटर

  • कॉलबैक

    function

    callback पैरामीटर ऐसा दिखता है:

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

    • आईडी

      स्ट्रिंग

    • reorderInfo

      ऑब्जेक्ट

      • childIds

        स्ट्रिंग[]

onCreated

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

बुकमार्क या फ़ोल्डर बनाए जाने पर सक्रिय होता है.

पैरामीटर

  • कॉलबैक

    function

    callback पैरामीटर ऐसा दिखता है:

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

    • आईडी

      स्ट्रिंग

    • बुकमार्क

onImportBegan

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

बुकमार्क इंपोर्ट करने का सेशन शुरू होने पर सक्रिय होता है. महंगे निरीक्षकों को oncreated अपडेट को तब तक अनदेखा करना चाहिए, जब तक onImportEnded को सक्रिय नहीं किया जाता. हालांकि, निगरानी करने वाले लोगों को अन्य सूचनाएं तुरंत मिलनी चाहिए.

पैरामीटर

  • कॉलबैक

    function

    callback पैरामीटर ऐसा दिखता है:

    () => void

onImportEnded

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

बुकमार्क इंपोर्ट सेशन खत्म होने पर सक्रिय होता है.

पैरामीटर

  • कॉलबैक

    function

    callback पैरामीटर ऐसा दिखता है:

    () => void

onMoved

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

किसी बुकमार्क या फ़ोल्डर को किसी दूसरे पैरंट फ़ोल्डर में ले जाने पर सक्रिय होता है.

पैरामीटर

  • कॉलबैक

    function

    callback पैरामीटर ऐसा दिखता है:

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

    • आईडी

      स्ट्रिंग

    • moveInfo

      ऑब्जेक्ट

      • इंडेक्स

        नंबर

      • oldIndex

        नंबर

      • oldParentId

        स्ट्रिंग

      • parentId

        स्ट्रिंग

onRemoved

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

बुकमार्क या फ़ोल्डर हटाए जाने पर सक्रिय होता है. जब किसी फ़ोल्डर को बार-बार हटाया जाता है, तो उस फ़ोल्डर के लिए सिर्फ़ एक सूचना ट्रिगर होती है और उसके कॉन्टेंट के लिए कोई सूचना चालू नहीं होती.

पैरामीटर

  • कॉलबैक

    function

    callback पैरामीटर ऐसा दिखता है:

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

    • आईडी

      स्ट्रिंग

    • removeInfo

      ऑब्जेक्ट

      • इंडेक्स

        नंबर

      • नोड
        Chrome 48 और उसके बाद के वर्शन
      • parentId

        स्ट्रिंग