標籤:
Install:
npm i --save firebase // v3.2.1
Config Firebase:
First we need to require Firebase:
import firebase from ‘firebase‘;
Then in the component constructor, we need to init Firebase:
constructor(props){ super(props); // Initialize Firebase var config = { apiKey: "<api_key>", authDomain: "<authDomain>", databaseURL: "<databaseURL>", storageBucket: "<storageBucket>", }; firebase.initializeApp(config); }
The config you can easily get from the your Firebase App page.
Create new node: set()
writeUserData(userId, name, email, imageUrl) { firebase.database().ref(‘users/‘ + userId).set({ username: name, email: email, profile_picture : imageUrl }); }// calling this.writeUserData(1, "Zhentian Wan", ‘[email protected]‘, null);
Then one node will be created in the "users" node, uid is "1".
Create new Child node: push()
appendOneMoreUser(name, email, imageUrl){ let ref = firebase.database().ref().child(‘users‘).push({ username: name, email: email }); this.updateMe("Yoona", "[email protected]", ref.key); }// callingthis.appendOneMoreUser("Yuri", ‘[email protected]‘, null);
So under "users" node, we want to append one new node, the uid will be generated randomly.
The "ref" object contains "key" prop which ref to the uid in the database.
Update one node: update()
updateMe(name, email, key){ const update = { username: name, email }; let ref = firebase.database().ref(‘users/‘ + key).update(update) .then((res)=>{ console.log("Data has been updated "); }); }// calling:const ref = firsebase.database().ref().child(‘users‘).push(user);this.updateMe("Yoona", "[email protected]", ref.key);
update() and set() methods both return Promise. So you can chaining .then() onto it.
Delete node: remove()
deleteMe(){ firebase.database().ref(‘users/1‘).remove(); }
Delete the uid = 1 user.
[React Native + Firebase] React Native: Real time database with Firebase -- setup & CRUD