IDBKeyRange: only() 靜態方法

Baseline 已廣泛支援

此特性已相當成熟,可在許多裝置和瀏覽器版本上使用。自 ⁨2015 年 7 月⁩以來,各瀏覽器均已提供此特性。

注意:此功能在 Web Workers 中可用。

only() 靜態方法是 IDBKeyRange 介面的一個方法,它建立一個包含單個值的新鍵範圍。

語法

js
IDBKeyRange.only(value)

引數

value

新鍵範圍的值。

返回值

IDBKeyRange: 新建立的鍵範圍。

異常

DataError DOMException

如果 value 引數不是有效鍵,則丟擲此異常。

示例

下面的示例說明了如何使用 only 鍵範圍。在這裡,我們宣告 keyRangeValue = IDBKeyRange.only("A"); — 一個僅包含值 "A" 的範圍。我們開啟一個事務(使用 IDBTransaction)和一個物件儲存,並使用 IDBObjectStore.openCursor 開啟一個遊標,將 keyRangeValue 宣告為其可選的鍵範圍值。這意味著遊標將僅檢索鍵值為 "A" 的記錄。

注意: 要獲得更完整的示例,允許您嘗試鍵範圍,請檢視我們的 IDBKeyRange 儲存庫(也可以 線上檢視示例)。

js
function displayData() {
  const keyRangeValue = IDBKeyRange.only("A");

  const transaction = db.transaction(["fThings"], "readonly");
  const objectStore = transaction.objectStore("fThings");

  objectStore.openCursor(keyRangeValue).onsuccess = (event) => {
    const cursor = event.target.result;
    if (cursor) {
      const listItem = document.createElement("li");
      listItem.textContent = `${cursor.value.fThing}, ${cursor.value.fRating}`;
      list.appendChild(listItem);

      cursor.continue();
    } else {
      console.log("Entries all displayed.");
    }
  };
}

規範

規範
Indexed Database API 3.0
# ref-for-dom-idbkeyrange-only①

瀏覽器相容性

另見