IDBCursor.advance()
IDBCursor インターフェイスの advance() メソッドはカーソルが位置を前進させる回数をセットします。
注: この機能は Web Worker 内で利用可能です
構文
js
cursor.advance(count);
引数
count-
カーソルが前進する回数
返値
例外
このメソッドは次のいずれかの DOMException を発生することがあります:
| 例外 | 説明 |
|---|---|
TransactionInactiveError |
この IDBCursor のトランザクションは活性化していません。 |
TypeError |
count パラメーターに渡された値がゼロや負の数です。 |
InvalidStateError |
カーソルは現在繰り返し中か、最後を過ぎています。 |
例
このシンプルな断片でトランザクションを作成し、オブジェクトストアを取得し、オブジェクトストアのレコードを一通り繰り返すカーソルを使っています。ここで cursor.advance(2) を使ってそれぞれ 2 回前進していて、つまり 1 つおきの結果だけが表示されます。advance() は IDBCursor.continue と同様に動作しますが、常に次のレコードに移動するのでなく、一度に複数のレコードを飛び越えられるのが違います。
注意点としてループの繰り返しで、カーソルオブジェクトの現在のレコードのテータを cursor.value.fooを使って取得できます。完全な動作例は、IDBCursor の例(ライブ例を見る)を見てください。
js
function advanceResult() {
list.innerHTML = '';
var transaction = db.transaction(['rushAlbumList'], "readonly");
var objectStore = transaction.objectStore('rushAlbumList');
objectStore.openCursor().onsuccess = function(event) {
var cursor = event.target.result;
if(cursor) {
var listItem = document.createElement('li');
listItem.innerHTML = '<strong>' + cursor.value.albumTitle + '</strong>, ' + cursor.value.year;
list.appendChild(listItem);
cursor.advance(2);
} else {
console.log('全エントリーを 1 つおきに表示しました。');
}
};
};
仕様書
| Specification |
|---|
| Indexed Database API 3.0 # ref-for-dom-idbcursor-advance① |
ブラウザーの互換性
BCD tables only load in the browser
関連情報
- IndexedDB を使用する
- トランザクションを開始する :
IDBDatabase - トランザクションを使用する :
IDBTransaction - キーレンジを設定する :
IDBKeyRange - データの取得と変更 :
IDBObjectStore - カーソルを使用する :
IDBCursor - リファレンスの例 : To-do Notifications (ライブ例を見る)