@firebase/firestore/lite

関数

関数 説明
function(app, ...)
getFirestore(app) 指定された FirebaseApp に関連付けられている既存のデフォルトの Firestore インスタンスを返します。インスタンスが存在しない場合は、新しいインスタンスをデフォルト設定で初期化します。
getFirestore(app, databaseId) (ベータ版)指定された FirebaseApp に関連付けられている既存の Firestore インスタンスを返します。インスタンスが存在しない場合は、新しいインスタンスをデフォルト設定で初期化します。
terraformFirestore(アプリ, 設定) 指定された設定で Cloud Firestore の新しいインスタンスを初期化します。他の関数(getFirestore() など)の前にのみ呼び出すことができます。カスタム設定が空の場合、この関数は getFirestore() の呼び出しと同じです。
InitializeFirestore(app, settings, databaseId) (ベータ版) 指定された設定で Cloud Firestore の新しいインスタンスを初期化します。他の関数(getFirestore() など)の前にのみ呼び出すことができます。カスタム設定が空の場合、この関数は getFirestore() の呼び出しと同じです。
function(firestore, ...) を参照してください。
collection(firestore, path, pathSegments) 指定された絶対パスにあるコレクションを参照する CollectionReference インスタンスを取得します。
collectionGroup(firestore, collectionId) 指定された collectionId のコレクションまたはサブコレクションに含まれるデータベース内のすべてのドキュメントを含む、新しい Query インスタンスを作成して返します。
connectFirestoreEmulator(ファイアストア、ホスト、ポート、オプション) このインスタンスを変更して、Cloud Firestore エミュレータと通信します。注: このインスタンスをオペレーションの実行に使用する前に、このインスタンスを呼び出す必要があります。
doc(firestore, path, pathSegments) 指定された絶対パスのドキュメントを参照する DocumentReference インスタンスを取得します。
runTransaction(firestore, updateFunction, options) 指定された updateFunction を実行し、トランザクション内で適用された変更を commit しようとします。トランザクション内で読み取られたドキュメントが変更されると、Cloud Firestore は updateFunction を再試行します。5 回試行しても commit に失敗した場合、トランザクションは失敗します。1 つのトランザクションで許可される最大書き込み回数は 500 回です。
terminate(firestore) 指定された Firestore インスタンスを終了します。terminate() を呼び出した後は、clearIndexedDbPersistence() 関数のみを使用できます。その他の関数は FirestoreError をスローします。終了によって保留中の書き込みはキャンセルされず、サーバーからの応答を待っている Promise は解決されません。終了後に再起動するには、getFirestore() を使用して Firestore の新しいインスタンスを作成します。注: 通常の状況では、terminate() を呼び出す必要はありません。この関数は、このインスタンスにすべてのリソースを解放させる場合、またはすべてのローカル状態がテスト実行の間に破棄されるように clearIndexedDbPersistence() と組み合わせて使用する場合にのみ有用です。
writeBatch(firestore) 複数の書き込みを単一のアトミック オペレーションとして実行するために使用する書き込みバッチを作成します。1 つの WriteBatch で許可される最大書き込み数は 500 です。これらの書き込みの結果は、返された Promise の解決後に行われるドキュメントの読み取りにのみ反映されます。クライアントがオフラインの場合、書き込みは失敗します。クライアントがオンラインになるまでローカルで変更を確認したり、書き込みをバッファしたりする場合は、完全な Firestore SDK を使用してください。
function()
count() クエリの結果セットに含まれるドキュメント数の計算に使用できる AggregateField オブジェクトを作成します。
deleteField() updateDoc() または setDoc(){merge: true} を指定してフィールドを削除するマークを付け、使用するセンチネルを返します。
documentId() ドキュメントの ID を参照する特別な標識 FieldPath を返します。クエリでドキュメント ID による並べ替えやフィルタリングに使用できます。
getFirestore() デフォルトの FirebaseApp に関連付けられている既存のデフォルトの Firestore インスタンスを返します。インスタンスが存在しない場合は、新しいインスタンスをデフォルト設定で初期化します。
serverTimestamp() サーバーで生成されたタイムスタンプを書き込まれるデータに含めるために setDoc() または updateDoc() で使用する標識を返します。
function(databaseId, ...) をご覧ください。
getFirestore(databaseId) (ベータ版)デフォルトの FirebaseApp に関連付けられている既存の Firestore インスタンスを返します。インスタンスが存在しない場合は、新しいインスタンスをデフォルト設定で初期化します。
function(elements, ...)
arrayRemove(elements) setDoc() で使用できるか、サーバーにすでに存在するすべての配列値から指定された要素を削除するようサーバーに指示する特別な値を返します。指定した各要素のすべてのインスタンスが配列から削除されます。変更されるフィールドがまだ配列でない場合、空の配列で上書きされます。
arrayUnion(elements) setDoc() または updateDoc() で指定できる特殊な値を返します。この値は、指定された要素をサーバーにすでに存在する任意の配列値と統合するようサーバーに指示します。指定した配列にまだ存在しない各要素は、末尾に追加されます。変更されるフィールドがまだ配列でない場合、指定された要素だけを含む配列で上書きされます。
function(field, ...)
average(field) クエリの結果セットに含まれる一連のドキュメントに対して指定されたフィールドの平均値を計算するために使用できる AggregateField オブジェクトを作成します。
sum(field) クエリの結果セットのドキュメント範囲に対して指定したフィールドの合計を計算するために使用できる AggregateField オブジェクトを作成します。
function(fieldPath, ...) をご覧ください。
orderBy(fieldPath, directStr) 指定したフィールドでクエリ結果を昇順ではなく降順で並べ替える QueryOrderByConstraint を作成します。注: 指定したフィールドが含まれていないドキュメントはクエリ結果に含まれません。
where(fieldPath, opStr, value) 指定されたフィールドがドキュメントに含まれる必要があり、その値が指定されたリレーション制約を満たすように強制する QueryFieldFilterConstraint を作成します。
function(fieldValues, ...) をご覧ください。
endAt(fieldValues) クエリの順序を基準にして、指定されたフィールドで結果セットが終わるように結果セットを変更する QueryEndAtConstraint を作成します。フィールド値の順序は、クエリの order by 句の順序と一致している必要があります。
endBefore(fieldValues) クエリの順序に応じて、結果セットが指定されたフィールドよりも前に終了するように変更する QueryEndAtConstraint を作成します。フィールド値の順序は、クエリの order by 句の順序と一致している必要があります。
startAfter(fieldValues) クエリの順序を基準にして、指定されたフィールドの後に結果セットが開始されるように結果セットを変更する QueryStartAtConstraint を作成します。フィールド値の順序は、クエリの order by 句の順序と一致している必要があります。
startAt(fieldValues) クエリの順序を基準にして、指定されたフィールドから結果セットが開始されるように結果セットを変更する QueryStartAtConstraint を作成します。フィールド値の順序は、クエリの order by 句の順序と一致している必要があります。
関数(左、...)
aggregateFieldEqual(left, right) 2 つの 'AggregateField` インスタンスを比較し、等価であるかどうかをチェックします。
aggregateQuerySnapshotEqual(left, right) 2 つの AggregateQuerySnapshot インスタンスが等しいかどうかを比較します。2 つの AggregateQuerySnapshot インスタンスは「等しい」とみなされます。基になるクエリが同じ比較対象であり、同じデータを持っている場合です。
queryEqual(left, right) 指定されたクエリが同じコレクションをポイントし、同じ制約を適用している場合、true を返します。
refEqual(left, right) 指定された参照が等しい場合は true を返します。
snapshotEqual(left, right) 指定されたスナップショットが等しい場合は true を返します。
function(limit, ...) を参照してください。
limit(limit) 最初に一致するドキュメントのみを返す QueryLimitConstraint を作成します。
limitToLast(limit) 最後に一致したドキュメントのみを返す QueryLimitConstraint を作成します。limitToLast クエリには少なくとも 1 つの orderBy 句を指定する必要があります。指定しない場合、実行時に例外がスローされます。
function(logLevel, ...) を参照してください。
setLogLevel(logLevel) Cloud Firestore ログの詳細度を設定します(デバッグ、エラー、サイレント)。
function(n, ...)
インクリメント(n) setDoc() または updateDoc() で使用できる特別な値を返します。この値は、フィールドの現在の値を指定された値で増分するようにサーバーに指示します。オペランドまたは現在のフィールド値のいずれかが浮動小数点精度を使用する場合、すべての演算は IEEE 754 セマンティクスに従います。両方の値が整数の場合、JavaScript の安全な数値範囲(Number.MIN_SAFE_INTEGERNumber.MAX_SAFE_INTEGER)外の値も精度が失われる可能性があります。さらに、Firestore バックエンドで処理されると、すべての整数演算は -2^63 から 2^63-1 の間で制限されます。現在のフィールド値が number 型でない場合、またはフィールドがまだ存在しない場合、変換によってフィールドは指定された値に設定されます。
function(query, ...)
getAggregate(query, aggregateSpec) 実際にドキュメントをダウンロードせずに、指定されたクエリの結果セットのドキュメントに対して、指定された集計値を計算します。この関数を使用すると、ドキュメントの最終的な集計値のみが集計されるため、集計が効率的になります。ダウンロードされます。結果セットが大きすぎて完全にダウンロードできない(数千のドキュメント)場合に、この関数はドキュメントの集計を実行できます。
getCount(query) ドキュメントを実際にダウンロードせずに、指定されたクエリの結果セットに含まれるドキュメントの数を計算します。この関数を使用するとドキュメントのカウントは効率的です。これは、ドキュメントのカウントではなく最終的なカウントのみであるため、効率的です。ダウンロードされます。この関数は、結果セットのサイズが大きすぎて完全にダウンロードできない(数千のドキュメント)場合に、ドキュメントをカウントできます。
getDocs(query) クエリを実行し、結果を QuerySnapshot として返します。すべてのクエリは、以前に実行されたクエリも含め、サーバーによって直接実行されます。最新の変更は、バックエンドによってすでに適用されている場合にのみ、取得結果に反映されます。クライアントがオフラインの場合、オペレーションは失敗します。以前にキャッシュに保存された結果とローカルの変更を表示するには、完全な Firestore SDK を使用してください。
query(query, compositeFilter, queryConstraints) 追加のクエリ制約も含むように拡張された Query の新しい不変インスタンスを作成します。
query(query, queryConstraints) 追加のクエリ制約も含むように拡張された Query の新しい不変インスタンスを作成します。
function(queryConstraints, ...)
and(queryConstraints) 指定されたフィルタ制約の結合である新しい QueryCompositeFilterConstraint を作成します。結合フィルタには、指定されたフィルタをすべて満たすドキュメントが含まれます。
or(queryConstraints) 指定されたフィルタ制約の分離である新しい QueryCompositeFilterConstraint を作成します。分離フィルタには、指定されたフィルタのいずれかを満たすドキュメントが含まれます。
function(reference, ...)
addDoc(reference, data) 指定されたデータを使用して、指定された CollectionReference に新しいドキュメントを追加し、ドキュメント ID を自動的に割り当てます。この書き込みの結果は、返された Promise の解決後に発生するドキュメントの読み取りにのみ反映されます。クライアントがオフラインの場合、書き込みは失敗します。クライアントがオンラインになるまでローカルで変更を確認したり、書き込みをバッファしたりする場合は、完全な Firestore SDK を使用してください。
collection(reference, path, pathSegments) 指定された相対パスで reference のサブコレクションを参照する CollectionReference インスタンスを取得します。
collection(reference, path, pathSegments) 指定された相対パスで reference のサブコレクションを参照する CollectionReference インスタンスを取得します。
deleteDoc(リファレンス) 指定された DocumentReference が参照するドキュメントを削除します。削除は、返された Promise の解決後に行われるドキュメントの読み取りにのみ反映されます。クライアントがオフラインの場合、削除は失敗します。クライアントがオンラインになるまでローカルで変更を確認したり、書き込みをバッファしたりする場合は、完全な Firestore SDK を使用してください。
doc(参照, パス, パスセグメント) 指定された相対パスで reference 内のドキュメントを参照する DocumentReference インスタンスを取得します。パスが指定されていない場合は、自動的に生成された一意の ID が、返される DocumentReference に使用されます。
doc(参照, パス, パスセグメント) 指定された相対パスで reference 内のドキュメントを参照する DocumentReference インスタンスを取得します。
getDoc(参照) 指定されたドキュメント参照で参照されているドキュメントを読み取ります。以前に読み取りまたは変更されたドキュメントも含め、すべてのドキュメントはサーバーから直接取得されます。最近の変更は、バックエンドによってすでに適用されている場合にのみ、取得された DocumentSnapshot に反映されます。クライアントがオフラインの場合、読み取りは失敗します。キャッシュを使用する場合やローカルの変更を表示する場合は、Firestore SDK 全体を使用してください。
setDoc(reference, data) 指定された DocumentReference によって参照されるドキュメントに書き込みます。ドキュメントがまだ存在しない場合は作成されます。この書き込みの結果は、返された Promise の解決後に行われるドキュメントの読み取りにのみ反映されます。クライアントがオフラインの場合、書き込みは失敗します。クライアントがオンラインになるまでローカルで変更を確認したり、書き込みをバッファしたりする場合は、完全な Firestore SDK を使用してください。
setDoc(reference, data, options) 指定された DocumentReference によって参照されるドキュメントに書き込みます。ドキュメントがまだ存在しない場合は作成されます。merge または mergeFields を指定すると、提供されたデータを既存のドキュメントにマージできます。この書き込みの結果は、返された Promise の解決後に発生するドキュメントの読み取りにのみ反映されます。クライアントがオフラインの場合、書き込みは失敗します。クライアントがオンラインになるまでローカルで変更を確認したり、書き込みをバッファしたりする場合は、完全な Firestore SDK を使用してください。
updateDoc(reference, data) 指定された DocumentReference によって参照されるドキュメント内のフィールドを更新します。存在しないドキュメントに適用すると、更新は失敗します。この更新の結果は、返された Promise の解決後に行われるドキュメントの読み取りにのみ反映されます。クライアントがオフラインの場合、更新は失敗します。クライアントがオンラインになるまでローカルで変更を確認したり、書き込みをバッファしたりする場合は、完全な Firestore SDK を使用してください。
updateDoc(reference, field, value, moreFieldsAndValues) 指定された DocumentReference で参照されるドキュメント内のフィールドの更新は、存在しないドキュメントに適用されると失敗します。ネストされたフィールドを更新するには、ドット区切りのフィールドパス文字列を指定するか、FieldPath オブジェクトを指定します。この更新の結果は、返された Promise の解決後に発生するドキュメントの読み取りにのみ反映されます。クライアントがオフラインの場合、更新は失敗します。クライアントがオンラインになるまでローカルで変更を確認したり、書き込みをバッファしたりする場合は、完全な Firestore SDK を使用してください。
function(snapshot, ...)
endAt(snapshot) 指定されたドキュメント(両端を含む)で終了するように結果セットを変更する QueryEndAtConstraint を作成します。終了位置は、クエリの順序に相対的です。ドキュメントには、クエリの orderBy で指定されたすべてのフィールドが含まれている必要があります。
endBefore(スナップショット) 指定したドキュメント(排他的)の前に終了するように結果セットを変更する QueryEndAtConstraint を作成します。終了位置は、クエリの順序に相対的です。ドキュメントには、クエリの orderBy で指定されたすべてのフィールドが含まれている必要があります。
startAfter(snapshot) 指定したドキュメント(含まない)の後に開始するように結果セットを変更する QueryStartAtConstraint を作成します。開始位置は、クエリの順序に相対的です。ドキュメントには、クエリの orderBy で指定されたすべてのフィールドが含まれている必要があります。
startAt(snapshot) 指定されたドキュメント(両端を含む)から開始するように結果セットを変更する QueryStartAtConstraint を作成します。開始位置は、クエリの順序に相対的です。ドキュメントには、このクエリの orderBy で指定されたすべてのフィールドが含まれている必要があります。
function(values, ...)
vector(values) 指定された数値配列のコピーで構築された新しい VectorValue を作成します。

クラス

クラス 説明
AggregateField Firestore が実行できる集計を表します。
AggregateQuerySnapshot 集計クエリの実行結果。
バイト バイト配列を表す不変オブジェクト。
CollectionReference CollectionReference オブジェクトは、ドキュメントの追加、ドキュメント参照の取得、ドキュメントのクエリ(query() を使用)に使用できます。
DocumentReference DocumentReference は Firestore データベース内のドキュメントの場所を参照し、場所の書き込み、読み取り、リッスンに使用できます。参照先の場所にドキュメントが存在する場合と存在しない場合があります。
DocumentSnapshot DocumentSnapshot には、Firestore データベースのドキュメントから読み取られたデータが含まれます。特定のフィールドを取得するには、.data() または .get(<field>) を使用してデータを抽出できます。存在しないドキュメントを指す DocumentSnapshot の場合、どのデータアクセスに対しても「未定義」が返されます。exists() メソッドを使用して、ドキュメントの存在を明示的に確認できます。
FieldPath FieldPath はドキュメント内のフィールドを参照します。パスは、単一のフィールド名(ドキュメント内の最上位フィールドを参照)にすることも、フィールド名のリスト(ドキュメント内のネストされたフィールドを参照)で構成することもできます。フィールド名を指定して FieldPath を作成します。複数のフィールド名が指定されている場合、パスはドキュメント内のネストされたフィールドを指します。
フィールド値 set() または update() でドキュメント フィールドを記述するときに使用できる Sentinel 値。
Firestore Cloud Firestore サービス インターフェース。このコンストラクタを直接呼び出さないでください。代わりに getFirestore() を使用してください。
FirestoreError Firestore オペレーションによって返されるエラー。
GeoPoint Firestore の地理的位置を表す不変オブジェクト。位置は緯度と経度のペアで表されます。緯度の値は [-90, 90] の範囲です。経度の値は [-180, 180] の範囲内です。
クエリ Query は、読み取りやリッスンが可能なクエリを指します。フィルタと順序を追加して、絞り込んだ Query オブジェクトを作成することもできます。
QueryCompositeFilterConstraint QueryCompositeFilterConstraint は、複数の QueryFieldFilterConstraint または QueryCompositeFilterConstraint の論理 OR または AND を実行して、Firestore クエリから返されるドキュメントのセットを絞り込むために使用されます。QueryCompositeFilterConstraint は、or() または and() を呼び出して作成され、その後 query() に渡して、QueryCompositeFilterConstraint を含む新しいクエリ インスタンスを作成できます。
QueryConstraint QueryConstraint は、Firestore クエリによって返されるドキュメントのセットを絞り込むために使用します。QueryConstraint は、where()orderBy()startAt()startAfter()endBefore()endAt()limit()limitToLast() に渡し、この QueryConstraintquery() も作成します。
QueryDocumentSnapshot QueryDocumentSnapshot には、クエリの一部として Firestore データベース内のドキュメントから読み取られたデータが含まれます。ドキュメントは存在することが保証されており、そのデータを .data() または .get(<field>) で抽出して特定のフィールドを取得できます。QueryDocumentSnapshotDocumentSnapshot と同じ API サーフェスを提供します。クエリ結果には既存のドキュメントのみが含まれるため、exists プロパティは常に true になり、data() が「未定義」を返すことはありません。
QueryEndAtConstraint QueryEndAtConstraint は、Firestore クエリによって返される結果セットからドキュメントを除外するために使用されます。QueryEndAtConstraint は、endAt() または endBefore() を呼び出して作成されます。これを query() に渡して、この QueryEndAtConstraint を含む新しいクエリ インスタンスを作成できます。
QueryFieldFilterConstraint QueryFieldFilterConstraint は、1 つ以上のドキュメント フィールドをフィルタして、Firestore クエリから返されるドキュメントのセットを絞り込むために使用します。QueryFieldFilterConstraint は、where() を呼び出すことで作成されます。次に、query() に渡して、この QueryFieldFilterConstraint を含む新しいクエリ インスタンスを作成できます。
QueryLimitConstraint QueryLimitConstraint は、Firestore クエリによって返されるドキュメントの数を制限するために使用されます。QueryLimitConstraint は、limit() または limitToLast() を呼び出すことで作成されます。その後、query() に渡して、この QueryLimitConstraint を含む新しいクエリ インスタンスを作成できます。
QueryOrderByConstraint QueryOrderByConstraint は、Firestore クエリによって返された一連のドキュメントを並べ替えるために使用します。QueryOrderByConstraint は、orderBy() を呼び出して作成され、その後 query() に渡して、この QueryOrderByConstraint を含む新しいクエリ インスタンスを作成できます。注: orderBy フィールドを含まないドキュメントはクエリ結果に表示されません。
QuerySnapshot QuerySnapshot には、クエリの結果を表す 0 個以上の DocumentSnapshot オブジェクトが含まれます。ドキュメントには、docs プロパティを介して配列としてアクセスすることも、forEach メソッドを使用して列挙することもできます。ドキュメントの数は、empty プロパティと size プロパティで確認できます。
QueryStartAtConstraint QueryStartAtConstraint は、Firestore クエリによって返される結果セットの先頭からドキュメントを除外するために使用されます。QueryStartAtConstraint は、startAt() または startAfter() を呼び出すことで作成されます。これを query() に渡して、この QueryStartAtConstraint を含む新しいクエリ インスタンスを作成できます。
タイムスタンプ Timestamp は、タイムゾーンやカレンダーに依存しない特定の時点を表し、UTC エポック時間のナノ秒単位の分解能で秒と小数点以下で表されます。これは、グレゴリオ暦を 1 年目まで遡る先発グレゴリオ暦を使用してエンコードされます。このエンコーディングでは、すべての分の長さが 60 秒であると仮定されています。つまり、うるう秒を無視することで、解釈にうるう秒テーブルが不要となっています。範囲は 0001-01-01T00:00:00Z ~ 9999-12-31T23:59:59.999999999Z です。例と詳細な仕様については、タイムスタンプの定義をご覧ください。
Transaction トランザクションへの参照。トランザクションの updateFunction に渡される Transaction オブジェクトは、トランザクション コンテキスト内でデータの読み書きを行うメソッドを提供します。runTransaction() をご覧ください。
VectorValue Firestore ドキュメントのベクトル型を表します。を使用してインスタンスを作成します。VectorValue
WriteBatch 書き込みバッチ。単一のアトミック単位として複数の書き込みを実行するために使用します。WriteBatch オブジェクトは、writeBatch() を呼び出して取得できます。書き込みバッチに書き込みを追加するためのメソッドが用意されています。WriteBatch.commit() が呼び出されるまで、書き込みは commit(またはローカルで表示)されません。

インターフェース

インターフェース 説明
AggregateSpec 集計とそのエイリアスのセットを指定します。
DocumentData ドキュメント データ(setDoc() で使用)は、値にマッピングされたフィールドで構成されます。
FirestoreDataConverter withConverter()AppModelType 型のユーザー オブジェクトを DbModelType 型の Firestore データに変換するために使用するコンバータ。このコンバータを使用すると、Firestore でオブジェクトを保存および取得する際に、汎用型の引数を指定できます。このコンテキストの「AppModel」は、関連する情報や機能をまとめるためにアプリケーションで使用されるクラスです。このようなクラスには、複雑なネストされたデータ型を持つプロパティ、メモ化に使用するプロパティ、Firestore でサポートされていない型のプロパティ(symbolbigint など)、複合オペレーションを実行するヘルパー関数などを含めることができます。このようなクラスは Firestore データベースへの保存には適していないか、保存できません。代わりに、そのようなクラスのインスタンスを「従来の JavaScript オブジェクト」に変換する必要があります。(POJO)このコンテキストでは、この型を「DbModel」と呼びます。Firestore での永続化に適したオブジェクトです利便性を考慮して、アプリケーションで FirestoreDataConverter を実装し、コンバータを DocumentReferenceQuery などの Firestore オブジェクトに登録することで、Firestore に保存する場合は AppModel を自動的に DbModel に変換し、Firestore から取得する場合は DbModelAppModel に変換できます。
設定 Cloud Firestore インスタンスのカスタム構成を指定します。これらの変数は、他のメソッドを呼び出す前に設定する必要があります。
TransactionOptions トランザクションの動作をカスタマイズするためのオプション。

型エイリアス

型エイリアス 説明
AddPrefixToKeys すべてのキーの先頭に、ドットに付加された外側のキーが付いた新しいマップを返します。
AggregateFieldType Firestore でサポートされているすべての AggregateField 型の結合。
AggregateSpecData キーが AggregateSpec から取得され、その値は入力 AggregateSpec からの対応する AggregateField によって実行された集計の結果である型。
集計タイプ 実行する集計型を表す共用体型。
ChildUpdateFields(子の更新フィールド) 指定された型 T1 のネストされたフィールドを計算するためのヘルパー。これは、undefined | {...}(オプションの prop で発生します)や {a: A} | {b: B} などの共用体型を配布するために必要です。このユースケースでは、T[K] は分散ではなく式として評価されるため、VRecordT[K] の共用体型を配布するために使用されます。https://www.typescriptlang.org/docs/handbook/advanced-types.html#distributive-conditional-types.html#distributive-conditional-types.
FirestoreErrorCode Firestore ステータス コードのセット。コードは、gRPC によって公開されているコードと同じです(https://github.com/grpc/grpc/blob/master/doc/statuscodes.md)。有効な値: - 'cancelled': オペレーションはキャンセルされました(通常は呼び出し元によって)。- 'unknown': 不明なエラーまたは別のエラードメインからのエラーです。- 'invalid-argument': クライアントが無効な引数を指定しました。これは「failed-precondition」とは異なることに注意してください。「無効な引数」は、システムの状態に関係なく問題がある引数を示します(無効なフィールド名など)。- 'deadline-exceeded': 操作が完了する前に期限が切れました。システムの状態を変更するオペレーションの場合、オペレーションが正常に終了しても、このエラーが返されることがあります。たとえば、サーバーからの正常なレスポンスが、期限切れになるほど遅延していた可能性があります。- 'not-found': リクエストされたドキュメントは見つかりませんでした。- 'Already-exists': 作成しようとしたドキュメントがすでに存在します。- 'permission-denied': 呼び出し元には、指定された操作を実行する権限がありません。- 'resource-exhausted': 一部のリソースが不足しています。ユーザーごとの割り当て、またはファイル システム全体で容量が不足している可能性があります。- 'failed-precondition': システムがオペレーションの実行に必要な状態ではないため、オペレーションが拒否されました。- 'aborted': オペレーションは中止されました。通常は、トランザクションの中止などの同時実行の問題が原因です。- 'out-of-range': オペレーションが有効な範囲を超えて試行されました。- 'unImplemented': オペレーションが実装されていないか、サポートまたは有効化されていません。- 'internal': 内部エラーです。基になるシステムで予期される一部の不変条件が破損していることを意味します。これらのエラーのいずれかが表示される場合、何かが著しく壊れています。- 「unavailable」: サービスは現在利用できません。これは一時的な状態である可能性が高く、バックオフで再試行することで修正できます。- 'data-loss': 回復不能なデータの損失または破損。- 'unauthenticated': リクエストに、操作のための有効な認証情報がありません。
NestedUpdateFields 各フィールド(「bar」など)で、ネストされたキーをすべて検索します(例: {'bar.baz': T1, 'bar.qux': T2})。それらのキーを組み合わせて 1 つのマップを作成します。このマップには、オプションとして指定されているキーをすべて含めます。
OrderByDirection orderBy() 句の方向は「desc」として指定されます。または「asc」(降順または昇順)。
PartialWithFieldValue TypeScript の Partial<T> に似ていますが、ネストされたフィールドを省略し、FieldValues をプロパティ値として渡すことができます。
プリミティブ プリミティブ型。
QueryConstraintType この SDK で使用できるさまざまなクエリ制約について説明します。
QueryFilterConstraint QueryFilterConstraint は、QueryFieldFilterConstraintQueryCompositeFilterConstraint を表すヘルパー ユニオン型です。
QueryNonFilterConstraint QueryNonFilterConstraint は、QueryConstraints を表すヘルパー ユニオン型です。これは、ドキュメント セットの絞り込みまたは並べ替えに使用されますが、ドキュメント フィールドで明示的にフィルタリングすることはありません。QueryNonFilterConstraint は、orderBy()startAt()startAfter()endBefore()endAt()limit()、または limitToLast() を呼び出して、query() を含む新しいクエリ インスタンスを作成することで作成されます。QueryConstraint
SetOptions setDoc() の動作を設定して呼び出すオプション オブジェクト。これらの呼び出しは、SetOptionsmerge: true を指定することで、ターゲット ドキュメント全体を上書きするのではなく、詳細なマージを実行するように構成できます。
UnionToIntersection 共用体型 U = T1 | T2 | ... を指定すると、交差型 (T1 & T2 & ...) を返します。分布条件型と、条件型からの推論を使用します。反バリアント位置にある同じ型変数の候補が複数あると、交差点の型が推測されるため、これはうまくいきます。https://www.typescriptlang.org/docs/handbook/advanced-types.html#type-inference-in-conditional-types https://stackoverflow.com/questions/50374908/transform-union-type-to-intersection-type
UpdateData 値にマッピングされたフィールドパス(「foo」や「foo.baz」など)で構成されるデータを更新します(updateDoc() で使用)。ドットを含むフィールドは、ドキュメント内のネストされたフィールドを参照します。FieldValues はプロパティ値として渡すことができます。
WhereFilterOp where() 句のフィルタ条件は、文字列「&lt;」、「&lt;='、==」、「!='」、「&gt;='」、「&gt;」、「array-contains」、「in」、「array-contains-any」、「not-in」を使用して指定します。
WithFieldValue 型の安全性を維持しながら FieldValues をプロパティ値として渡すことができます。

関数(アプリ、...)

getFirestore(アプリ)

指定された FirebaseApp に関連付けられている既存のデフォルトの Firestore インスタンスを返します。インスタンスが存在しない場合は、新しいインスタンスをデフォルト設定で初期化します。

署名:

export declare function getFirestore(app: FirebaseApp): Firestore;

パラメータ

パラメータ 説明
アプリ FirebaseApp 返された Firestore インスタンスが関連付けられている FirebaseApp インスタンス。

戻り値:

Firestore

指定されたアプリの Firestore インスタンス。

getFirestore(app, databaseId)

この API はデベロッパー向けのプレビュー版として提供されており、寄せられたフィードバックに基づいて変更される可能性があります。この API は本番環境で使用しないでください。

指定された FirebaseApp に関連付けられている既存の Firestore インスタンスを返します。インスタンスが存在しない場合は、新しいインスタンスをデフォルト設定で初期化します。

署名:

export declare function getFirestore(app: FirebaseApp, databaseId: string): Firestore;

パラメータ

パラメータ 説明
アプリ FirebaseApp 返された Firestore インスタンスが関連付けられている FirebaseApp インスタンス。
databaseId 文字列 データベースの名前。

戻り値:

Firestore

指定されたアプリの Firestore インスタンス。

初期化 Firestore(アプリ, 設定)

指定された設定で Cloud Firestore の新しいインスタンスを初期化します。他の関数(getFirestore() など)の前にのみ呼び出すことができます。カスタム設定が空の場合、この関数は getFirestore() の呼び出しと同じです。

署名:

export declare function initializeFirestore(app: FirebaseApp, settings: Settings): Firestore;

パラメータ

パラメータ 説明
アプリ FirebaseApp Firestore インスタンスが関連付けられる FirebaseApp
設定 設定 Firestore インスタンスを構成するための設定オブジェクト。

戻り値:

Firestore

新たに初期化された Firestore インスタンス。

InitializeFirestore(app, settings, databaseId)

この API はデベロッパー向けのプレビュー版として提供されており、寄せられたフィードバックに基づいて変更される可能性があります。この API は本番環境で使用しないでください。

指定された設定で Cloud Firestore の新しいインスタンスを初期化します。他の関数(getFirestore() など)の前にのみ呼び出すことができます。カスタム設定が空の場合、この関数は getFirestore() の呼び出しと同じです。

署名:

export declare function initializeFirestore(app: FirebaseApp, settings: Settings, databaseId?: string): Firestore;

パラメータ

パラメータ 説明
アプリ FirebaseApp Firestore インスタンスが関連付けられる FirebaseApp
設定 設定 Firestore インスタンスを構成するための設定オブジェクト。
databaseId 文字列 データベースの名前。

戻り値:

Firestore

新たに初期化された Firestore インスタンス。

関数(firestore, ...)

コレクション(firestore、path、pathSegments)

指定された絶対パスにあるコレクションを参照する CollectionReference インスタンスを取得します。

署名:

export declare function collection(firestore: Firestore, path: string, ...pathSegments: string[]): CollectionReference<DocumentData, DocumentData>;

パラメータ

パラメータ 説明
firestore Firestore ルート Firestore インスタンスへの参照。
パス 文字列 コレクションへのスラッシュ区切りパス。
pathSegments string[] 最初の引数を基準として適用する追加のパスセグメント。

戻り値:

CollectionReference<DocumentDataDocumentData>

CollectionReference インスタンス。

例外

最終的なパスのセグメント数が偶数で、コレクションを参照していない場合。

collectionGroup(firestore, collectionId)

指定された collectionId を持つコレクションまたはサブコレクションに含まれるデータベース内のすべてのドキュメントを含む、新しい Query インスタンスを作成して返します。

署名:

export declare function collectionGroup(firestore: Firestore, collectionId: string): Query<DocumentData, DocumentData>;

パラメータ

パラメータ 説明
firestore Firestore ルート Firestore インスタンスへの参照。
collectionId 文字列 クエリ対象のコレクションを指定します。この ID をパスの最後のセグメントとするすべてのコレクションまたはサブコレクションが含まれます。スラッシュを含めることはできません。

戻り値:

Query<DocumentData, DocumentData>

作成された Query

connectFirestoreEmulator(ファイアストア、ホスト、ポート、オプション)

このインスタンスを変更して、Cloud Firestore エミュレータと通信します。

署名:

export declare function connectFirestoreEmulator(firestore: Firestore, host: string, port: number, options?: {
    mockUserToken?: EmulatorMockTokenOptions | string;
}): void;

パラメータ

パラメータ 説明
firestore Firestore エミュレータに接続するように構成する Firestore インスタンス。
ホスト 文字列 インストールします(例: localhost)。
ポート 数値 (例: 9000)。
オプション { mockUserToken?:EmulatorMockTokenOptions |string;}

戻り値:

void

doc(firestore、path、pathSegments)

指定された絶対パスのドキュメントを参照する DocumentReference インスタンスを取得します。

署名:

export declare function doc(firestore: Firestore, path: string, ...pathSegments: string[]): DocumentReference<DocumentData, DocumentData>;

パラメータ

パラメータ 説明
firestore Firestore ルート Firestore インスタンスへの参照。
パス 文字列 スラッシュで区切られたドキュメントへのパス。
pathSegments string[] 最初の引数を基準として適用される追加のパスセグメント。

戻り値:

DocumentReference<DocumentDataDocumentData>

DocumentReference インスタンス。

例外

最終的なパスのセグメント数が奇数で、ドキュメントを参照していない場合。

runTransaction(firestore, updateFunction, options)

指定された updateFunction を実行し、トランザクション内で適用された変更を commit しようとします。トランザクション内で読み取られたドキュメントが変更されると、Cloud Firestore は updateFunction を再試行します。5 回試行しても commit に失敗すると、トランザクションは失敗します。

1 回のトランザクションで許可される最大書き込み回数は 500 回です。

署名:

export declare function runTransaction<T>(firestore: Firestore, updateFunction: (transaction: Transaction) => Promise<T>, options?: TransactionOptions): Promise<T>;

パラメータ

パラメータ 説明
firestore Firestore このトランザクションを実行する Firestore データベースへの参照。
updateFunction (トランザクション: Transaction)=>Promise<T> トランザクション コンテキスト内で実行する関数。
オプション TransactionOptions commit の最大試行回数を構成するオプション オブジェクト。

戻り値:

Promise<T>

トランザクションが正常に完了したか、明示的に中止された(updateFunction が失敗した Promise を返した)場合は、updateFunction によって返された Promise がここに返されます。トランザクションが失敗した場合は、拒否された Promise と対応する失敗エラーが返されます。

終了(firestore)

指定された Firestore インスタンスを終了します。

terminate() を呼び出した後は、clearIndexedDbPersistence() 関数のみを使用できます。その他の関数は FirestoreError をスローします。終了によって保留中の書き込みはキャンセルされず、サーバーからの応答を待っている Promise は解決されません。

終了後に再起動するには、getFirestore() を使用して Firestore の新しいインスタンスを作成します。

署名:

export declare function terminate(firestore: Firestore): Promise<void>;

パラメータ

パラメータ 説明
firestore Firestore 終了する Firestore インスタンス。

戻り値:

約束 <void>

インスタンスが正常に終了したときに解決される Promise

writeBatch(firestore)

複数の書き込みを単一のアトミック オペレーションとして実行するために使用する書き込みバッチを作成します。1 つの WriteBatch で許可される最大書き込み数は 500 です。

これらの書き込みの結果は、返された Promise が解決された後に発生するドキュメントの読み取りにのみ反映されます。クライアントがオフラインの場合、書き込みは失敗します。クライアントがオンラインになるまでローカルで変更を確認したり、書き込みをバッファしたりする場合は、完全な Firestore SDK を使用してください。

署名:

export declare function writeBatch(firestore: Firestore): WriteBatch;

パラメータ

パラメータ 説明
firestore Firestore

戻り値:

WriteBatch

複数の書き込みをアトミックに実行するために使用できる WriteBatch

関数

count()

クエリの結果セットに含まれるドキュメント数の計算に使用できる AggregateField オブジェクトを作成します。

署名:

export declare function count(): AggregateField<number>;

戻り値:

AggregateField<number>

deleteField()

updateDoc() または setDoc(){merge: true} を指定してフィールドを削除するマークを付け、使用するセンチネルを返します。

署名:

export declare function deleteField(): FieldValue;

戻り値:

フィールド値

documentId()

ドキュメントの ID を参照する特別な標識 FieldPath を返します。クエリでドキュメント ID による並べ替えやフィルタリングに使用できます。

署名:

export declare function documentId(): FieldPath;

戻り値:

FieldPath

getFirestore()

デフォルトの FirebaseApp に関連付けられている既存のデフォルトの Firestore インスタンスを返します。インスタンスが存在しない場合は、新しいインスタンスをデフォルト設定で初期化します。

署名:

export declare function getFirestore(): Firestore;

戻り値:

Firestore

指定されたアプリの Firestore インスタンス。

serverTimestamp()

サーバーで生成されたタイムスタンプを書き込まれるデータに含めるために setDoc() または updateDoc() で使用する標識を返します。

署名:

export declare function serverTimestamp(): FieldValue;

戻り値:

フィールド値

function(databaseId, ...)

getFirestore(databaseId)

この API はデベロッパー向けのプレビュー版として提供されており、寄せられたフィードバックに基づいて変更される可能性があります。この API は本番環境で使用しないでください。

デフォルトの FirebaseApp に関連付けられている既存の Firestore インスタンスを返します。インスタンスが存在しない場合は、新しいインスタンスをデフォルト設定で初期化します。

署名:

export declare function getFirestore(databaseId: string): Firestore;

パラメータ

パラメータ 説明
databaseId 文字列 データベースの名前。

戻り値:

Firestore

指定されたアプリの Firestore インスタンス。

関数(要素, ...)

配列削除(要素)

setDoc() で使用できるか、サーバーにすでに存在するすべての配列値から指定された要素を削除するようサーバーに指示する特別な値を返します。指定した各要素のすべてのインスタンスが配列から削除されます。変更されるフィールドがまだ配列でない場合、空の配列で上書きされます。

署名:

export declare function arrayRemove(...elements: unknown[]): FieldValue;

パラメータ

パラメータ 説明
要素 不明 [] 配列から削除する要素。

戻り値:

フィールド値

setDoc() または updateDoc() への呼び出しで使用する FieldValue 標識

arrayUnion(elements)

setDoc() または updateDoc() で指定できる特殊な値を返します。この値は、指定された要素をサーバーにすでに存在する任意の配列値と統合するようサーバーに指示します。指定した配列にまだ存在しない各要素は、末尾に追加されます。変更されるフィールドがまだ配列でない場合、指定された要素だけを含む配列で上書きされます。

署名:

export declare function arrayUnion(...elements: unknown[]): FieldValue;

パラメータ

パラメータ 説明
要素 不明 [] 結合して配列にする要素です。

戻り値:

フィールド値

setDoc() または updateDoc() への呼び出しで使用する FieldValue 標識。

function(field, ...)

average(field)

クエリの結果セットに含まれる一連のドキュメントに対して指定されたフィールドの平均値を計算するために使用できる AggregateField オブジェクトを作成します。

署名:

export declare function average(field: string | FieldPath): AggregateField<number | null>;

パラメータ

パラメータ 説明
フィールド 文字列 |FieldPath 結果セット全体で平均化するフィールドを指定します。

戻り値:

AggregateField<number |null>

sum(field)

クエリの結果セットのドキュメント範囲に対して指定したフィールドの合計を計算するために使用できる AggregateField オブジェクトを作成します。

署名:

export declare function sum(field: string | FieldPath): AggregateField<number>;

パラメータ

パラメータ 説明
フィールド 文字列 |FieldPath 結果セット全体で合計するフィールドを指定します。

戻り値:

AggregateField<number>

function(fieldPath, ...)

orderBy(fieldPath, directionalStr)

指定されたフィールドでクエリ結果を昇順ではなく降順で並べ替える QueryOrderByConstraint を作成します。

署名:

export declare function orderBy(fieldPath: string | FieldPath, directionStr?: OrderByDirection): QueryOrderByConstraint;

パラメータ

パラメータ 説明
fieldPath 文字列 |FieldPath 並べ替えに使用するフィールド。
方向 Str OrderByDirection 並べ替えの方向(「asc」または「desc」)(省略可)。指定しない場合、順序は昇順になります。

戻り値:

QueryOrderByConstraint

作成された QueryOrderByConstraint

ここで(fieldPath, opStr, value)

指定されたフィールドがドキュメントに含まれる必要があり、その値が指定されたリレーション制約を満たすように強制する QueryFieldFilterConstraint を作成します。

署名:

export declare function where(fieldPath: string | FieldPath, opStr: WhereFilterOp, value: unknown): QueryFieldFilterConstraint;

パラメータ

パラメータ 説明
fieldPath 文字列 |FieldPath 比較するパス
OpStr WhereFilterOp 演算文字列(例: "&lt;"、"&lt;="、"=="、"&lt;"、"&lt;="、"!=")。
不明 比較の値

戻り値:

QueryFieldFilterConstraint

作成された QueryFieldFilterConstraint

function(fieldValues, ...)

endAt(fieldValues)

クエリの順序を基準にして、指定されたフィールドで結果セットが終わるように結果セットを変更する QueryEndAtConstraint を作成します。フィールド値の順序は、クエリの order by 句の順序と一致している必要があります。

署名:

export declare function endAt(...fieldValues: unknown[]): QueryEndAtConstraint;

パラメータ

パラメータ 説明
fieldValues 不明 [] クエリの並べ替え順で、このクエリを終了するフィールド値。

戻り値:

QueryEndAtConstraint

query() に渡す QueryEndAtConstraint

endBefore(fieldValues)

クエリの順序に応じて、結果セットが指定されたフィールドよりも前に終了するように変更する QueryEndAtConstraint を作成します。フィールド値の順序は、クエリの order by 句の順序と一致している必要があります。

署名:

export declare function endBefore(...fieldValues: unknown[]): QueryEndAtConstraint;

パラメータ

パラメータ 説明
fieldValues 不明 [] このクエリを終了するフィールド値(クエリの順序で並べ替え)。

戻り値:

QueryEndAtConstraint

query() に渡す QueryEndAtConstraint

startAfter(fieldValues)

クエリの順序を基準にして、指定されたフィールドの後に結果セットが開始されるように結果セットを変更する QueryStartAtConstraint を作成します。フィールド値の順序は、クエリの order by 句の順序と一致している必要があります。

署名:

export declare function startAfter(...fieldValues: unknown[]): QueryStartAtConstraint;

パラメータ

パラメータ 説明
fieldValues 不明 [] クエリの順序で並べ替えられた、このクエリを開始するフィールド値。

戻り値:

QueryStartAtConstraint

query() に渡す QueryStartAtConstraint

startAt(fieldValues)

クエリの順序を基準にして、指定されたフィールドから結果セットが開始されるように結果セットを変更する QueryStartAtConstraint を作成します。フィールド値の順序は、クエリの order by 句の順序と一致している必要があります。

署名:

export declare function startAt(...fieldValues: unknown[]): QueryStartAtConstraint;

パラメータ

パラメータ 説明
fieldValues 不明 [] クエリの順序で並べ替えられた、このクエリを開始するフィールド値。

戻り値:

QueryStartAtConstraint

query() に渡す QueryStartAtConstraint

関数(左、...)

aggregateFieldEqual(left, right)

2 つの 'AggregateField` インスタンスを比較し、等価であるかどうかをチェックします。

署名:

export declare function aggregateFieldEqual(left: AggregateField<unknown>, right: AggregateField<unknown>): boolean;

パラメータ

パラメータ 説明
AggregateField<unknown> この AggregateField を right と比較します。
AggregateField<unknown> この AggregateField を left と比較します。

戻り値:

ブール値

aggregateQuerySnapshotEqual(left, right)

2 つの AggregateQuerySnapshot インスタンスが等価であるかどうかを比較します。

2 つの AggregateQuerySnapshot インスタンスが「等しい」と見なされます基になるクエリが同じ比較対象であり、同じデータを持っている場合です。

署名:

export declare function aggregateQuerySnapshotEqual<AggregateSpecType extends AggregateSpec, AppModelType, DbModelType extends DocumentData>(left: AggregateQuerySnapshot<AggregateSpecType, AppModelType, DbModelType>, right: AggregateQuerySnapshot<AggregateSpecType, AppModelType, DbModelType>): boolean;

パラメータ

パラメータ 説明
AggregateQuerySnapshot<AggregateSpecType、AppModelType、DbModelType> 比較する最初の AggregateQuerySnapshot
AggregateQuerySnapshot<AggregateSpecType、AppModelType、DbModelType> 比較する 2 番目の AggregateQuerySnapshot

戻り値:

ブール値

上記で定義されているようにオブジェクトが「等しい」場合は true、それ以外の場合は false

queryEqual(左, 右)

指定されたクエリが同じコレクションをポイントし、同じ制約を適用している場合、true を返します。

署名:

export declare function queryEqual<AppModelType, DbModelType extends DocumentData>(left: Query<AppModelType, DbModelType>, right: Query<AppModelType, DbModelType>): boolean;

パラメータ

パラメータ 説明
Query<AppModelType、DbModelType> 比較する Query
Query<AppModelType、DbModelType> 比較する Query

戻り値:

ブール値

参照が同じ Firestore データベース内の同じ場所を指している場合は true。

refEqual(左, 右)

指定された参照が等しい場合は true を返します。

署名:

export declare function refEqual<AppModelType, DbModelType extends DocumentData>(left: DocumentReference<AppModelType, DbModelType> | CollectionReference<AppModelType, DbModelType>, right: DocumentReference<AppModelType, DbModelType> | CollectionReference<AppModelType, DbModelType>): boolean;

パラメータ

パラメータ 説明
DocumentReference<AppModelType、DbModelType>|CollectionReference<AppModelType、DbModelType> 比較するリファレンス。
DocumentReference<AppModelType、DbModelType>|CollectionReference<AppModelType、DbModelType> 比較するリファレンス。

戻り値:

ブール値

参照が同じ Firestore データベース内の同じ場所を指している場合は true。

snapshotEqual(左、右)

指定されたスナップショットが等しい場合は true を返します。

署名:

export declare function snapshotEqual<AppModelType, DbModelType extends DocumentData>(left: DocumentSnapshot<AppModelType, DbModelType> | QuerySnapshot<AppModelType, DbModelType>, right: DocumentSnapshot<AppModelType, DbModelType> | QuerySnapshot<AppModelType, DbModelType>): boolean;

パラメータ

パラメータ 説明
DocumentSnapshot<AppModelType、DbModelType>|QuerySnapshot<AppModelType、DbModelType> 比較するスナップショット。
DocumentSnapshot<AppModelType、DbModelType>|QuerySnapshot<AppModelType、DbModelType> 比較するスナップショット。

戻り値:

ブール値

スナップショットが等しい場合は true を返します。

function(limit, ...)

制限(limit)

最初に一致するドキュメントのみを返す QueryLimitConstraint を作成します。

署名:

export declare function limit(limit: number): QueryLimitConstraint;

パラメータ

パラメータ 説明
limit 数値 返す最大アイテム数。

戻り値:

QueryLimitConstraint

作成された QueryLimitConstraint です。

limitToLast(limit)

最後に一致したドキュメントのみを返す QueryLimitConstraint を作成します。

limitToLast クエリには少なくとも 1 つの orderBy 句を指定する必要があります。指定しない場合、実行時に例外がスローされます。

署名:

export declare function limitToLast(limit: number): QueryLimitConstraint;

パラメータ

パラメータ 説明
limit 数値 返す最大アイテム数。

戻り値:

QueryLimitConstraint

作成された QueryLimitConstraint です。

function(logLevel, ...)

setLogLevel(logLevel)

Cloud Firestore ログの詳細度を設定します(デバッグ、エラー、サイレント)。

署名:

export declare function setLogLevel(logLevel: LogLevel): void;

パラメータ

パラメータ 説明
logLevel LogLevel アクティビティとエラーのロギングに設定した詳細度。次のいずれかの値を指定できます。
  • debug: 最も詳細なログレベル(主にデバッグ用)。
  • error - エラーのみをログに記録します。
  • silent to turn off logging.

戻り値:

void

関数(n, ...)

インクリメント(n)

フィールドの現在の値を指定された値だけ増やすようサーバーに指示する setDoc() または updateDoc() で使用できる特別な値を返します。

オペランドまたは現在のフィールド値のいずれかで浮動小数点精度を使用する場合、すべての演算は IEEE 754 セマンティクスに従います。両方の値が整数の場合、JavaScript の安全な数値範囲(Number.MIN_SAFE_INTEGERNumber.MAX_SAFE_INTEGER)外の値も精度が失われる可能性があります。さらに、Firestore バックエンドで処理されると、すべての整数演算は -2^63 から 2^63-1 の間で制限されます。

現在のフィールド値の型が number でない場合、またはフィールドがまだ存在しない場合、変換により、指定された値にフィールドが設定されます。

署名:

export declare function increment(n: number): FieldValue;

パラメータ

パラメータ 説明
n 数値 増加させる値。

戻り値:

フィールド値

setDoc() または updateDoc() への呼び出しで使用する FieldValue 標識

function(query, ...)

getAggregate(query, aggregateSpec)

実際にドキュメントをダウンロードせずに、指定されたクエリの結果セットに含まれるドキュメントに対して、指定された集計を計算します。

この関数を使用して集計を行うと効率的です。ドキュメントの集計値ではなく最終的な集計値のみが集計されるため、ダウンロードされます。結果セットが大きすぎて完全にダウンロードできない(数千のドキュメント)場合に、この関数はドキュメントの集計を実行できます。

署名:

export declare function getAggregate<AggregateSpecType extends AggregateSpec, AppModelType, DbModelType extends DocumentData>(query: Query<AppModelType, DbModelType>, aggregateSpec: AggregateSpecType): Promise<AggregateQuerySnapshot<AggregateSpecType, AppModelType, DbModelType>>;

パラメータ

パラメータ 説明
クエリ Query<AppModelType、DbModelType> 結果セットが集計されるクエリ。
集計仕様 AggregateSpecType 結果セットに対して実行する集計を指定する AggregateSpec オブジェクト。AggregateSpec は、集計結果を取得するために使用できる各集計のエイリアスを指定します。

戻り値:

Promise<AggregateQuerySnapshot<AggregateSpecType, AppModelType, DbModelType>>

const aggregateSnapshot = await getAggregate(query, {
  countOfDocs: count(),
  totalHours: sum('hours'),
  averageScore: average('score')
});

const countOfDocs: number = aggregateSnapshot.data().countOfDocs;
const totalHours: number = aggregateSnapshot.data().totalHours;
const averageScore: number | null = aggregateSnapshot.data().averageScore;

getCount(クエリ)

実際にドキュメントをダウンロードせずに、指定されたクエリの結果セットに含まれるドキュメントの数を計算します。

この関数を使用してドキュメントのカウントを行うと効率的です。これは、ドキュメントのカウントではなく、最終的なカウントのみが行われるためです。ダウンロードされます。この関数は、結果セットのサイズが大きすぎて完全にダウンロードできない(数千のドキュメント)場合に、ドキュメントをカウントできます。

署名:

export declare function getCount<AppModelType, DbModelType extends DocumentData>(query: Query<AppModelType, DbModelType>): Promise<AggregateQuerySnapshot<{
    count: AggregateField<number>;
}, AppModelType, DbModelType>>;

パラメータ

パラメータ 説明
クエリ Query<AppModelType、DbModelType> 結果セットのサイズを計算するクエリ。

戻り値:

Promise<AggregateQuerySnapshot<{ count: AggregateField<number>;}、AppModelType、DbModelType>>

カウントで解決される Promiseカウントは snapshot.data().count から取得できます。ここで、snapshot は、返された Promise が解決する AggregateQuerySnapshot です。

getDocs(query)

クエリを実行し、結果を QuerySnapshot として返します。

すべてのクエリは、以前に実行されたクエリも含め、サーバーによって直接実行されます。最新の変更は、バックエンドによってすでに適用されている場合にのみ、取得結果に反映されます。クライアントがオフラインの場合、オペレーションは失敗します。以前にキャッシュに保存された結果とローカルの変更を表示するには、完全な Firestore SDK を使用してください。

署名:

export declare function getDocs<AppModelType, DbModelType extends DocumentData>(query: Query<AppModelType, DbModelType>): Promise<QuerySnapshot<AppModelType, DbModelType>>;

パラメータ

パラメータ 説明
クエリ Query<AppModelType、DbModelType> 実行する Query

戻り値:

Promise<QuerySnapshot<AppModelType, DbModelType>>

クエリの結果によって解決される Promise。

query(query、compositeFilter、queryConstraints)

追加のクエリ制約も含むように拡張された Query の新しい不変インスタンスを作成します。

署名:

export declare function query<AppModelType, DbModelType extends DocumentData>(query: Query<AppModelType, DbModelType>, compositeFilter: QueryCompositeFilterConstraint, ...queryConstraints: QueryNonFilterConstraint[]): Query<AppModelType, DbModelType>;

パラメータ

パラメータ 説明
クエリ Query<AppModelType、DbModelType> 新しい制約のベースとして使用する Query インスタンス。
複合フィルタ QueryCompositeFilterConstraint 適用する QueryCompositeFilterConstraintand() または or() を使用して QueryCompositeFilterConstraint を作成します。
queryConstraints QueryNonFilterConstraint[] 適用する追加の QueryNonFilterConstraint(例: orderBy()limit())。

戻り値:

Query<AppModelType、DbModelType>

例外

指定されたクエリ制約のいずれかを、既存の制約または新しい制約と組み合わせることができない場合。

query(query, queryConstraints)

追加のクエリ制約も含むように拡張された Query の新しい不変インスタンスを作成します。

署名:

export declare function query<AppModelType, DbModelType extends DocumentData>(query: Query<AppModelType, DbModelType>, ...queryConstraints: QueryConstraint[]): Query<AppModelType, DbModelType>;

パラメータ

パラメータ 説明
クエリ Query<AppModelType、DbModelType> 新しい制約のベースとして使用する Query インスタンス。
queryConstraints QueryConstraint[] 適用する QueryConstraint のリスト。

戻り値:

Query<AppModelType、DbModelType>

例外

指定されたクエリ制約のいずれかを、既存の制約または新しい制約と組み合わせることができない場合。

関数(queryConstraints, ...)

and(queryConstraints)

指定されたフィルタ制約の結合である新しい QueryCompositeFilterConstraint を作成します。結合フィルタには、指定されたフィルタをすべて満たすドキュメントが含まれます。

署名:

export declare function and(...queryConstraints: QueryFilterConstraint[]): QueryCompositeFilterConstraint;

パラメータ

パラメータ 説明
queryConstraints QueryFilterConstraint[] 省略可。結合を実行する QueryFilterConstraint のリスト。これらを作成するには、where()or()and() のいずれかを呼び出します。

戻り値:

QueryCompositeFilterConstraint

新しく作成された QueryCompositeFilterConstraint

or(queryConstraints)

指定されたフィルタ制約の分離である新しい QueryCompositeFilterConstraint を作成します。分離フィルタには、指定されたフィルタのいずれかを満たすドキュメントが含まれます。

署名:

export declare function or(...queryConstraints: QueryFilterConstraint[]): QueryCompositeFilterConstraint;

パラメータ

パラメータ 説明
queryConstraints QueryFilterConstraint[] 省略可。分離を実行する QueryFilterConstraint のリスト。これらを作成するには、where()or()and() のいずれかを呼び出します。

戻り値:

QueryCompositeFilterConstraint

新しく作成された QueryCompositeFilterConstraint

function(reference, ...)

addDoc(reference, data)

指定されたデータを含む新しいドキュメントを、指定された CollectionReference に追加し、ドキュメント ID を自動的に割り当てます。

この書き込みの結果は、返された Promise が解決された後に発生するドキュメントの読み取りにのみ反映されます。クライアントがオフラインの場合、書き込みは失敗します。クライアントがオンラインになるまでローカルで変更を確認したり、書き込みをバッファしたりする場合は、完全な Firestore SDK を使用してください。

署名:

export declare function addDoc<AppModelType, DbModelType extends DocumentData>(reference: CollectionReference<AppModelType, DbModelType>, data: WithFieldValue<AppModelType>): Promise<DocumentReference<AppModelType, DbModelType>>;

パラメータ

パラメータ 説明
リファレンス CollectionReference<AppModelType、DbModelType> このドキュメントの追加先コレクションへの参照。
データ WithFieldValue<AppModelType> 新しいドキュメントのデータを含むオブジェクト。

戻り値:

Promise<DocumentReference<AppModelType, DbModelType>>

バックエンドに書き込まれた後、新しく作成されたドキュメントを指す DocumentReference で解決された Promise

例外

エラー - 指定された入力が有効な Firestore ドキュメントでない場合。

コレクション(参照、パス、パスセグメント)

指定された相対パスで reference のサブコレクションを参照する CollectionReference インスタンスを取得します。

署名:

export declare function collection<AppModelType, DbModelType extends DocumentData>(reference: CollectionReference<AppModelType, DbModelType>, path: string, ...pathSegments: string[]): CollectionReference<DocumentData, DocumentData>;

パラメータ

パラメータ 説明
リファレンス CollectionReference<AppModelType、DbModelType> コレクションへの参照。
パス 文字列 コレクションへのスラッシュ区切りパス。
pathSegments string[] 最初の引数を基準として適用する追加のパスセグメント。

戻り値:

CollectionReference<DocumentDataDocumentData>

CollectionReference インスタンス。

例外

最終的なパスのセグメント数が偶数で、コレクションを参照していない場合。

コレクション(参照、パス、パスセグメント)

指定された相対パスで reference のサブコレクションを参照する CollectionReference インスタンスを取得します。

署名:

export declare function collection<AppModelType, DbModelType extends DocumentData>(reference: DocumentReference<AppModelType, DbModelType>, path: string, ...pathSegments: string[]): CollectionReference<DocumentData, DocumentData>;

パラメータ

パラメータ 説明
リファレンス DocumentReference<AppModelType、DbModelType> Firestore ドキュメントへの参照。
パス 文字列 コレクションへのスラッシュ区切りパス。
pathSegments string[] 最初の引数を基準として適用される追加のパスセグメント。

戻り値:

CollectionReference<DocumentDataDocumentData>

CollectionReference インスタンス。

例外

最終的なパスのセグメント数が偶数で、コレクションを参照していない場合。

deleteDoc(参照)

指定された DocumentReference によって参照されるドキュメントを削除します。

削除は、返された Promise が解決された後に行われるドキュメントの読み取りにのみ反映されます。クライアントがオフラインの場合、削除は失敗します。クライアントがオンラインになるまでローカルで変更を確認したり、書き込みをバッファしたりする場合は、完全な Firestore SDK を使用してください。

署名:

export declare function deleteDoc<AppModelType, DbModelType extends DocumentData>(reference: DocumentReference<AppModelType, DbModelType>): Promise<void>;

パラメータ

パラメータ 説明
リファレンス DocumentReference<AppModelType、DbModelType> 削除するドキュメントの参照。

戻り値:

約束 <void>

ドキュメントがバックエンドから正常に削除されると、Promise が解決されました。

doc(参照、パス、パスセグメント)

指定された相対パスで reference 内のドキュメントを参照する DocumentReference インスタンスを取得します。パスが指定されていない場合、自動的に生成された一意の ID が、返される DocumentReference に使用されます。

署名:

export declare function doc<AppModelType, DbModelType extends DocumentData>(reference: CollectionReference<AppModelType, DbModelType>, path?: string, ...pathSegments: string[]): DocumentReference<AppModelType, DbModelType>;

パラメータ

パラメータ 説明
リファレンス CollectionReference<AppModelType、DbModelType> コレクションへの参照。
パス 文字列 スラッシュで区切られたドキュメントへのパス。自動生成された ID を使用する場合は省略する必要があります。
pathSegments string[] 最初の引数を基準として適用される追加のパスセグメント。

戻り値:

DocumentReference<AppModelType、DbModelType>

DocumentReference インスタンス。

例外

最終的なパスのセグメント数が奇数で、ドキュメントを参照していない場合。

doc(参照、パス、パスセグメント)

指定された相対パスで reference 内のドキュメントを参照する DocumentReference インスタンスを取得します。

署名:

export declare function doc<AppModelType, DbModelType extends DocumentData>(reference: DocumentReference<AppModelType, DbModelType>, path: string, ...pathSegments: string[]): DocumentReference<DocumentData, DocumentData>;

パラメータ

パラメータ 説明
リファレンス DocumentReference<AppModelType、DbModelType> Firestore ドキュメントへの参照。
パス 文字列 スラッシュで区切られたドキュメントへのパス。
pathSegments string[] 最初の引数を基準として適用される追加のパスセグメント。

戻り値:

DocumentReference<DocumentDataDocumentData>

DocumentReference インスタンス。

例外

最終的なパスのセグメント数が奇数で、ドキュメントを参照していない場合。

getDoc(参照)

指定されたドキュメント参照によって参照されているドキュメントを読み取ります。

以前に読み取りまたは変更されたドキュメントも含め、すべてのドキュメントがサーバーから直接取得されます。最近の変更は、バックエンドによってすでに適用されている場合にのみ、取得された DocumentSnapshot に反映されます。クライアントがオフラインの場合、読み取りは失敗します。キャッシュを使用する場合やローカルの変更を表示する場合は、Firestore SDK 全体を使用してください。

署名:

export declare function getDoc<AppModelType, DbModelType extends DocumentData>(reference: DocumentReference<AppModelType, DbModelType>): Promise<DocumentSnapshot<AppModelType, DbModelType>>;

パラメータ

パラメータ 説明
リファレンス DocumentReference<AppModelType、DbModelType> 取得するドキュメントの参照。

戻り値:

Promise<DocumentSnapshot<AppModelType, DbModelType>>

現在のドキュメントの内容を含む DocumentSnapshot で解決された Promise。

setDoc(reference, data)

指定された DocumentReference によって参照されるドキュメントに書き込みます。ドキュメントがまだ存在しない場合は作成されます。

この書き込みの結果は、返された Promise が解決された後に発生するドキュメントの読み取りにのみ反映されます。クライアントがオフラインの場合、書き込みは失敗します。クライアントがオンラインになるまでローカルで変更を確認したり、書き込みをバッファしたりする場合は、完全な Firestore SDK を使用してください。

署名:

export declare function setDoc<AppModelType, DbModelType extends DocumentData>(reference: DocumentReference<AppModelType, DbModelType>, data: WithFieldValue<AppModelType>): Promise<void>;

パラメータ

パラメータ 説明
リファレンス DocumentReference<AppModelType、DbModelType> 作成するドキュメントへの参照。
データ WithFieldValue<AppModelType> ドキュメントのフィールドと値のマップ。

戻り値:

約束 <void>

データがバックエンドに正常に書き込まれると、Promise が解決されます。

例外

エラー - 指定された入力が有効な Firestore ドキュメントでない場合。

setDoc(参照, データ, オプション)

指定された DocumentReference によって参照されるドキュメントに書き込みます。ドキュメントがまだ存在しない場合は作成されます。merge または mergeFields を指定すると、指定されたデータを既存のドキュメントに統合できます。

この書き込みの結果は、返された Promise が解決された後に発生するドキュメントの読み取りにのみ反映されます。クライアントがオフラインの場合、書き込みは失敗します。クライアントがオンラインになるまでローカルで変更を確認したり、書き込みをバッファしたりする場合は、完全な Firestore SDK を使用してください。

署名:

export declare function setDoc<AppModelType, DbModelType extends DocumentData>(reference: DocumentReference<AppModelType, DbModelType>, data: PartialWithFieldValue<AppModelType>, options: SetOptions): Promise<void>;

パラメータ

パラメータ 説明
リファレンス DocumentReference<AppModelType、DbModelType> 作成するドキュメントへの参照。
データ PartialWithFieldValue<AppModelType> ドキュメントのフィールドと値のマップ。
オプション SetOptions 設定動作を構成するオブジェクト。

戻り値:

約束 <void>

データがバックエンドに正常に書き込まれると、Promise が解決されます。

例外

エラー - 指定された入力が有効な Firestore ドキュメントでない場合。

updateDoc(reference, data)

指定された DocumentReference によって参照されるドキュメント内のフィールドを更新します。存在しないドキュメントに適用すると、更新は失敗します。

この更新の結果は、返された Promise が解決された後に発生するドキュメントの読み取りにのみ反映されます。クライアントがオフラインの場合、更新は失敗します。クライアントがオンラインになるまでローカルで変更を確認したり、書き込みをバッファしたりする場合は、完全な Firestore SDK を使用してください。

署名:

export declare function updateDoc<AppModelType, DbModelType extends DocumentData>(reference: DocumentReference<AppModelType, DbModelType>, data: UpdateData<DbModelType>): Promise<void>;

パラメータ

パラメータ 説明
リファレンス DocumentReference<AppModelType、DbModelType> 更新するドキュメントへの参照。
データ UpdateData<DbModelType> ドキュメントの更新に使用するフィールドと値を含むオブジェクト。フィールドには、ドキュメント内のネストされたフィールドを参照するドットを含めることができます。

戻り値:

約束 <void>

データがバックエンドに正常に書き込まれると、Promise が解決されます。

例外

エラー - 指定された入力が有効な Firestore データでない場合。

updateDoc(参照, フィールド, 値, moreFieldsAndValues)

指定された DocumentReference によって参照されるドキュメント内のフィールドを更新します。存在しないドキュメントに更新を適用すると、更新は失敗します。

ネストされたフィールドを更新するには、ドット区切りのフィールドパス文字列を指定するか、FieldPath オブジェクトを指定します。

この更新の結果は、返された Promise が解決された後に発生するドキュメントの読み取りにのみ反映されます。クライアントがオフラインの場合、更新は失敗します。クライアントがオンラインになるまでローカルで変更を確認したり、書き込みをバッファしたりする場合は、完全な Firestore SDK を使用してください。

署名:

export declare function updateDoc<AppModelType, DbModelType extends DocumentData>(reference: DocumentReference<AppModelType, DbModelType>, field: string | FieldPath, value: unknown, ...moreFieldsAndValues: unknown[]): Promise<void>;

パラメータ

パラメータ 説明
リファレンス DocumentReference<AppModelType、DbModelType> 更新するドキュメントへの参照。
フィールド 文字列 |FieldPath 更新する最初のフィールドです。
不明 1 つ目の値です。
moreFieldsAndValues 不明 [] 追加の Key-Value ペア。

戻り値:

約束 <void>

データがバックエンドに正常に書き込まれると、Promise が解決されます。

例外

エラー - 指定された入力が有効な Firestore データでない場合。

関数(スナップショット、...)

endAt(スナップショット)

指定されたドキュメント(両端を含む)で終了するように結果セットを変更する QueryEndAtConstraint を作成します。終了位置は、クエリの順序に相対的です。ドキュメントには、クエリの orderBy で指定されたすべてのフィールドが含まれている必要があります。

署名:

export declare function endAt<AppModelType, DbModelType extends DocumentData>(snapshot: DocumentSnapshot<AppModelType, DbModelType>): QueryEndAtConstraint;

パラメータ

パラメータ 説明
スナップショット DocumentSnapshot<AppModelType、DbModelType> 終了するドキュメントのスナップショット。

戻り値:

QueryEndAtConstraint

query() に渡す QueryEndAtConstraint

endBefore(スナップショット)

指定したドキュメント(排他的)の前に終了するように結果セットを変更する QueryEndAtConstraint を作成します。終了位置は、クエリの順序に相対的です。ドキュメントには、クエリの orderBy で指定されたすべてのフィールドが含まれている必要があります。

署名:

export declare function endBefore<AppModelType, DbModelType extends DocumentData>(snapshot: DocumentSnapshot<AppModelType, DbModelType>): QueryEndAtConstraint;

パラメータ

パラメータ 説明
スナップショット DocumentSnapshot<AppModelType、DbModelType> 終了前に終了するドキュメントのスナップショット。

戻り値:

QueryEndAtConstraint

query() に渡す QueryEndAtConstraint

startAfter(スナップショット)

指定したドキュメント(含まない)の後に開始するように結果セットを変更する QueryStartAtConstraint を作成します。開始位置は、クエリの順序に相対的です。ドキュメントには、クエリの orderBy で指定されたすべてのフィールドが含まれている必要があります。

署名:

export declare function startAfter<AppModelType, DbModelType extends DocumentData>(snapshot: DocumentSnapshot<AppModelType, DbModelType>): QueryStartAtConstraint;

パラメータ

パラメータ 説明
スナップショット DocumentSnapshot<AppModelType、DbModelType> 開始後のドキュメントのスナップショット。

戻り値:

QueryStartAtConstraint

query() に渡す QueryStartAtConstraint

startAt(スナップショット)

指定されたドキュメント(両端を含む)から開始するように結果セットを変更する QueryStartAtConstraint を作成します。開始位置は、クエリの順序に相対的です。ドキュメントには、このクエリの orderBy で指定されたすべてのフィールドが含まれている必要があります。

署名:

export declare function startAt<AppModelType, DbModelType extends DocumentData>(snapshot: DocumentSnapshot<AppModelType, DbModelType>): QueryStartAtConstraint;

パラメータ

パラメータ 説明
スナップショット DocumentSnapshot<AppModelType、DbModelType> 開始位置のドキュメントのスナップショット。

戻り値:

QueryStartAtConstraint

query() に渡す QueryStartAtConstraint

関数(値, ...)

ベクトル(値)

指定された数値配列のコピーで構築された新しい VectorValue を作成します。

署名:

export declare function vector(values?: number[]): VectorValue;

パラメータ

パラメータ 説明
values 数値 [] この数値配列のコピーを使用して VectorValue インスタンスを作成します。

戻り値:

VectorValue

指定された数値配列のコピーで構築された新しい VectorValue

AddPrefixToKeys

すべてのキーの先頭に、ドットに付加された外側のキーが付いた新しいマップを返します。

署名:

export declare type AddPrefixToKeys<Prefix extends string, T extends Record<string, unknown>> = {
    [K in keyof T & string as `${Prefix}.${K}`]+?: string extends K ? any : T[K];
};

集計フィールド タイプ

Firestore でサポートされているすべての AggregateField 型の結合。

署名:

export declare type AggregateFieldType = ReturnType<typeof sum> | ReturnType<typeof average> | ReturnType<typeof count>;

AggregateSpecData

キーが AggregateSpec から取得され、その値は入力 AggregateSpec からの対応する AggregateField によって実行された集計の結果である型。

署名:

export declare type AggregateSpecData<T extends AggregateSpec> = {
    [P in keyof T]: T[P] extends AggregateField<infer U> ? U : never;
};

集計タイプ

実行する集計型を表す共用体型。

署名:

export declare type AggregateType = 'count' | 'avg' | 'sum';

ChildUpdateFields

指定された型 T1 のネストされたフィールドを計算するためのヘルパー。これは、undefined | {...}(オプションの prop で使用)や {a: A} | {b: B} などの共用体タイプを配布するために必要です。

このユースケースでは、T[K] は分散ではなく式として評価されるため、V を使用して RecordT[K] の共用体型を分散します。

https://www.typescriptlang.org/docs/handbook/advanced-types.html#distributive-conditional-types をご覧ください。

署名:

export declare type ChildUpdateFields<K extends string, V> = V extends Record<string, unknown> ? AddPrefixToKeys<K, UpdateData<V>> : never;

FirestoreErrorCode

Firestore ステータス コードのセット。コードは、gRPC によって公開されているコードと同じです: https://github.com/grpc/grpc/blob/master/doc/statuscodes.md

可能な値: - 'cancelled': オペレーションはキャンセルされました(通常は呼び出し元によって)。- 'unknown': 不明なエラーまたは別のエラードメインからのエラーです。- 'invalid-argument': クライアントが無効な引数を指定しました。これは「failed-precondition」とは異なることに注意してください。「無効な引数」は、システムの状態に関係なく問題がある引数を示します(無効なフィールド名など)。- 'deadline-exceeded': 操作が完了する前に期限が切れました。システムの状態を変更するオペレーションの場合、オペレーションが正常に終了しても、このエラーが返されることがあります。たとえば、サーバーからの正常なレスポンスが、期限切れになるほど遅延していた可能性があります。- 'not-found': リクエストされたドキュメントは見つかりませんでした。- 'Already-exists': 作成しようとしたドキュメントがすでに存在します。- 'permission-denied': 呼び出し元には、指定された操作を実行する権限がありません。- 'resource-exhausted': 一部のリソースが不足しています。ユーザーごとの割り当て、またはファイル システム全体で容量が不足している可能性があります。- 'failed-precondition': システムがオペレーションの実行に必要な状態ではないため、オペレーションが拒否されました。- 'aborted': オペレーションは中止されました。通常は、トランザクションの中止などの同時実行の問題が原因です。- 'out-of-range': オペレーションが有効な範囲を超えて試行されました。- 'unImplemented': オペレーションが実装されていないか、サポートまたは有効化されていません。- 'internal': 内部エラーです。基になるシステムで予期される一部の不変条件が破損していることを意味します。これらのエラーのいずれかが表示される場合、何かが著しく壊れています。- 「unavailable」: サービスは現在利用できません。これは一時的な状態である可能性が高く、バックオフで再試行することで修正できます。- 'data-loss': 回復不能なデータの損失または破損。- 'unauthenticated': リクエストに、操作のための有効な認証情報がありません。

署名:

export declare type FirestoreErrorCode = 'cancelled' | 'unknown' | 'invalid-argument' | 'deadline-exceeded' | 'not-found' | 'already-exists' | 'permission-denied' | 'resource-exhausted' | 'failed-precondition' | 'aborted' | 'out-of-range' | 'unimplemented' | 'internal' | 'unavailable' | 'data-loss' | 'unauthenticated';

ネストされた更新フィールド

各フィールド(「bar」など)で、ネストされたキーをすべて検索します(例: {'bar.baz': T1, 'bar.qux': T2})。それらのキーを組み合わせて 1 つのマップを作成します。このマップには、オプションとして指定されているキーをすべて含めます。

署名:

export declare type NestedUpdateFields<T extends Record<string, unknown>> = UnionToIntersection<{
    [K in keyof T & string]: ChildUpdateFields<K, T[K]>;
}[keyof T & string]>;

OrderByDirection

orderBy() 句の方向は「desc」として指定されます。または「asc」(降順または昇順)。

署名:

export declare type OrderByDirection = 'desc' | 'asc';

PartialWithFieldValue

TypeScript の Partial<T> に似ていますが、ネストされたフィールドを省略し、FieldValues をプロパティ値として渡すことができます。

署名:

export declare type PartialWithFieldValue<T> = Partial<T> | (T extends Primitive ? T : T extends {} ? {
    [K in keyof T]?: PartialWithFieldValue<T[K]> | FieldValue;
} : never);

基本ロール

プリミティブ型。

署名:

export declare type Primitive = string | number | boolean | undefined | null;

QueryConstraintType

この SDK で使用できるさまざまなクエリ制約について説明します。

署名:

export declare type QueryConstraintType = 'where' | 'orderBy' | 'limit' | 'limitToLast' | 'startAt' | 'startAfter' | 'endAt' | 'endBefore';

QueryFilterConstraints

QueryFilterConstraint は、QueryFieldFilterConstraintQueryCompositeFilterConstraint を表すヘルパー ユニオン型です。

署名:

export declare type QueryFilterConstraint = QueryFieldFilterConstraint | QueryCompositeFilterConstraint;

QueryNonFilterConstraint

QueryNonFilterConstraint は、QueryConstraints を表すヘルパー ユニオン型です。これは、ドキュメント セットの絞り込みまたは並べ替えに使用されますが、ドキュメント フィールドで明示的にフィルタリングすることはありません。QueryNonFilterConstraint は、orderBy()startAt()startAfter()endBefore()endAt()limit()、または limitToLast() を呼び出して、query() を含む新しいクエリ インスタンスを作成することで作成されます。QueryConstraint

署名:

export declare type QueryNonFilterConstraint = QueryOrderByConstraint | QueryLimitConstraint | QueryStartAtConstraint | QueryEndAtConstraint;

SetOptions

setDoc() の動作を設定して呼び出すオプション オブジェクト。これらの呼び出しは、SetOptionsmerge: true を指定することで、ターゲット ドキュメント全体を上書きするのではなく、詳細なマージを実行するように構成できます。

署名:

export declare type SetOptions = {
    readonly merge?: boolean;
} | {
    readonly mergeFields?: Array<string | FieldPath>;
};

UnionToIntersection

共用体型 U = T1 | T2 | ... の場合、交差型 (T1 & T2 & ...) を返します。

分布条件型と、条件型からの推論を使用します。反バリアント位置にある同じ型変数の候補が複数あると、交差点の型が推測されるため、これはうまくいきます。https://www.typescriptlang.org/docs/handbook/advanced-types.html#type-inference-in-conditional-types https://stackoverflow.com/questions/50374908/transform-union-type-to-intersection-type

署名:

export declare type UnionToIntersection<U> = (U extends unknown ? (k: U) => void : never) extends (k: infer I) => void ? I : never;

データの更新

値にマッピングされたフィールドパス(「foo」や「foo.baz」など)で構成されるデータを更新します(updateDoc() で使用)。ドットを含むフィールドは、ドキュメント内のネストされたフィールドを参照します。FieldValues はプロパティ値として渡すことができます。

署名:

export declare type UpdateData<T> = T extends Primitive ? T : T extends {} ? {
    [K in keyof T]?: UpdateData<T[K]> | FieldValue;
} & NestedUpdateFields<T> : Partial<T>;

WhereFilterOp

where() 句のフィルタ条件は、文字列「&lt;」、「&lt;='、==」、「!='」、「&gt;='」、「&gt;」、「array-contains」、「in」、「array-contains-any」、「not-in」を使用して指定します。

署名:

export declare type WhereFilterOp = '<' | '<=' | '==' | '!=' | '>=' | '>' | 'array-contains' | 'in' | 'array-contains-any' | 'not-in';

WithFieldValue

型の安全性を維持しながら FieldValues をプロパティ値として渡すことができます。

署名:

export declare type WithFieldValue<T> = T | (T extends Primitive ? T : T extends {} ? {
    [K in keyof T]: WithFieldValue<T[K]> | FieldValue;
} : never);