0

0

在 React Native 中创建 Firestore 文档到指定集合的教程

碧海醫心

碧海醫心

发布时间:2025-09-14 22:39:24

|

1031人浏览过

|

来源于php中文网

原创

在 react native 中创建 firestore 文档到指定集合的教程

本文档旨在指导开发者如何在 React Native 应用中使用 Firebase Firestore SDK (v9 及以上版本) 创建文档到指定集合中。我们将详细讲解如何使用模块化的 Firebase 语法,避免常见的 TypeError: undefined is not a function 错误,并提供清晰的代码示例和注意事项,帮助开发者快速上手。

使用 Firebase Firestore SDK (v9+) 创建文档

在 React Native 项目中使用 Firebase Firestore,特别是创建文档到特定集合时,需要注意 Firebase SDK 的版本和相应的语法。 如果你的项目中使用的是 Firebase SDK v9 及以上版本,那么必须使用模块化的语法。 混合使用旧版本(v8 及之前)的命名空间语法和新版本的模块化语法会导致错误,例如 TypeError: undefined is not a function。

以下是如何正确配置和使用 Firebase Firestore SDK (v9+) 在 React Native 应用中创建文档的步骤:

1. 安装 Firebase 依赖

首先,确保你的 React Native 项目已经安装了必要的 Firebase 依赖。如果还没有安装,可以使用以下命令进行安装:

npm install @react-native-firebase/app @react-native-firebase/firestore @react-native-firebase/auth

或者使用 yarn:

yarn add @react-native-firebase/app @react-native-firebase/firestore @react-native-firebase/auth

2. 初始化 Firebase

在你的 firebaseConfig.js 文件中,使用模块化的方式初始化 Firebase:

import { initializeApp } from 'firebase/app';
import { getFirestore } from 'firebase/firestore';
import { getAuth } from 'firebase/auth';

const firebaseConfig = {
  apiKey: "...",
  authDomain: "...",
  projectId: "...",
  storageBucket: "...",
  messagingSenderId: "...",
  appId: "...",
  measurementId: "..."
};

const app = initializeApp(firebaseConfig);
const db = getFirestore(app);
const auth = getAuth(app);

export { auth, db };

3. 创建文档到指定集合

Cutout.Pro抠图
Cutout.Pro抠图

AI批量抠图去背景

下载

在你的注册函数或者其他需要创建文档的地方,使用 setDoc 和 doc 函数来创建文档。 假设你有一个 team 变量和一个 user.uid 变量,你需要将 userProfile 数据保存到以 team 为名称的集合中,并将文档 ID 设置为 user.uid。

import { auth, db } from '../firebaseConfig';
import { createUserWithEmailAndPassword } from "firebase/auth";
import { doc, setDoc } from "firebase/firestore";

const registerUser = async (email, password, confirmPassword, firstName, lastName, team) => {
  if (password !== confirmPassword) {
    alert("Passwords don't match.");
    return;
  }

  try {
    const userCredential = await createUserWithEmailAndPassword(auth, email, password);
    const { user } = userCredential;
    const userProfile = {
      uid: user.uid,
      firstName,
      lastName,
      email,
      team,
      fullførteKurs: [],
    };

    try {
      // 使用 setDoc 和 doc 创建文档
      await setDoc(doc(db, team, user.uid), userProfile);
      alert('User registered successfully');
    } catch (error) {
      console.error("Error creating user document: ", error);
      alert('Error creating user document: ' + error.message);
    }
  } catch (error) {
    alert(error.message);
  }
};

export default registerUser;

代码解释:

  • import { doc, setDoc } from "firebase/firestore";: 导入必要的函数。 doc 函数用于创建一个对文档的引用,setDoc 函数用于将数据写入文档。
  • doc(db, team, user.uid): 创建一个文档引用。 db 是你的 Firestore 实例,team 是集合的名称,user.uid 是文档的 ID。
  • setDoc(doc(db, team, user.uid), userProfile): 将 userProfile 数据写入到指定的文档中。

4. 错误处理

在 try...catch 块中处理可能出现的错误,并使用 console.error 记录错误信息。 建议在alert中显示error.message,方便调试。

注意事项:

  • 确保 Firebase SDK 版本正确: 确认你的项目使用的是 Firebase SDK v9 及以上版本。
  • 使用模块化语法: 始终使用模块化的语法来调用 Firebase 函数。
  • 检查 Firebase 配置: 确保你的 Firebase 配置正确,并且你的应用有权限访问 Firestore。
  • 处理权限问题: 确保你的 Firestore 安全规则允许你创建文档。

总结:

通过遵循以上步骤,你可以在 React Native 应用中使用 Firebase Firestore SDK (v9+) 创建文档到指定的集合中。 关键在于使用模块化的语法,正确导入所需的函数,并确保你的 Firebase 配置和安全规则正确设置。 遵循这些最佳实践可以避免常见的错误,并确保你的应用能够安全可靠地与 Firestore 交互。

相关专题

更多
scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

184

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

263

2023.10.25

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

508

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

241

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

248

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5219

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

470

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

205

2023.09.04

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3.1万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 0.9万人学习

React核心原理新老生命周期精讲
React核心原理新老生命周期精讲

共12课时 | 1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号