zoukankan      html  css  js  c++  java
  • [AngularFire2 & Firestore] Example for collection and doc

    import {Injectable} from '@angular/core';
    import {Skill} from '../models/skills';
    import {AuthService} from '../../auth/services/auth.service';
    
    import 'rxjs/add/operator/do';
    import 'rxjs/add/operator/startWith';
    import 'rxjs/add/operator/catch';
    import {Observable} from 'rxjs/Observable';
    import {AngularFirestore, AngularFirestoreCollection} from 'angularfire2/firestore';
    
    
    @Injectable()
    export class SkillsService {
    
      skillCollection: AngularFirestoreCollection<Skill>;
      skills: Observable<Skill[]>;
      events: Observable<any>;
    
      constructor(private afs: AngularFirestore,
                  private authService: AuthService) {
    
        this.skillCollection = afs.collection(`users/${this.uid}/skills`,
          ref => ref.orderBy('name').limit(10));
        this.events = this.skillCollection.auditTrail();
      }
    
      get uid() {
        return this.authService.user.uid;
      }
    
      getSkills(): Observable<Skill[]> {
        return this.skillCollection
          .snapshotChanges()
          .startWith([]) // To solve the snapshotChange doesn't fire for empty data
          .map((actions) =>
            actions.map(({payload}) => ({id: payload.doc.id, ...payload.doc.data()} as Skill))
          );
      }
    
      getSkill(key): Observable<Skill> {
        return this.afs.doc(`users/${this.uid}/skills/${key}`)
          .snapshotChanges()
          .map(({payload}) => ({id: payload.id, ...payload.data()} as Skill));
      }
    
      addSkill(skill: Skill) {
        return this.skillCollection.add(skill);
      }
    
      updateSkill(key: string, skill: Partial<Skill>) {
        return this.afs.doc<Skill>(`users/${this.uid}/skills/${key}`).update(skill);
      }
    
      removeSkill(key: string) {
        return this.afs.doc<Skill>(`users/${this.uid}/skills/${key}`).delete();
      }
    
    }
  • 相关阅读:
    Apache Solr入门教程(初学者之旅)
    Codeforces 631 (Div. 2) E. Drazil Likes Heap 贪心
    Codeforces 631 (Div. 2) D. Dreamoon Likes Sequences 位运算^ 组合数 递推
    Codeforces 631 (Div. 2) C. Dreamoon Likes Coloring 思维or构造
    python中的类型转换
    MVC3.0在各个版本IIS中的部署
    get和post的区别
    Vue和React对比
    谈谈你对web标注和W3c的理解和认识
    js中的undefined 和null
  • 原文地址:https://www.cnblogs.com/Answer1215/p/7770409.html
Copyright © 2011-2022 走看看