我正在使用Firebase和React,我有这些集合:
所以它就像sheets/userId/sheetId/sheetData
我如何得到最后两张(在这个例子中只有两张),其中包含来自/sheetsData
的所有数据,格式很好,所以我可以将它存储在Redux商店中。感谢
答案 0 :(得分:1)
首先,您需要获取用户ID ....有很多方法可以做到这一点。以下是我个人使用的两个例子。
// ********* Add a listener from the database to monitor whos logged in. *********
firebase.auth().onAuthStateChanged((user) => {
// ********* If a user is logged in firebase will return the user object. THEY ARE NOT LOGGED IN THOUGH *********
if (user) {
console.log('onAuthStateChanged', user)
// ********* Then we call an official Firebase function through actions, this would probably be getSheets() for you *********
this.props.loginRequest(user);
} else {
console.log('No user signed in')
}
});
// ********* After logging in the found user from above we need to set them to redux store *********
let signedInUser = firebase.auth().currentUser;
if (signedInUser) {
this.props.loginRequest(signedInUser);
console.log('currentUserSignedIn', signedInUser)
} else {
console.log('no active user', signedInUser)
}
获取用户ID后,您可以调用redux操作来获取此用户的快照,其中包含对象对象中的所有工作表。
firebase.database().ref('users/' + user.uid).once('value').then(function (snapshot) {
// ******** This method is straight from their docs ********
// ******** It returns whatever is found at the path
xxxxx/users/user.uid ********
let username = snapshot.val();
console.log(' FOUND THIS USER FROM THE DB', username);
// now dispatch whatever redux store action you have to store the user
information
dispatch(userSet(username))
})
.catch((err) => console.log(err));
最后,我建议将工作表存储为一系列对象,因为目前看起来您正在使用firebase的推送方法,该方法为每个新工作表创建唯一的ID。这使得对它们的操作变得困难,因为firebase将向您返回一个对象对象,您无法在不知道每个唯一ID的情况下使用.map,.filter或.forEach。
以下是我使用firebase登录https://github.com/GavinThomas1192/motoMechanicMeeKanic/blob/master/App/Actions/auth-actions.js
的方法我喜欢在本地打包对象并将其设置一次以避免深度嵌套firebase。