属性“ id”在类型“ void”上不存在

时间:2019-07-23 07:54:34

标签: angular typescript firebase angular7 angularfire2

我正在尝试为我的有角度的应用程序的所有操作实施审核跟踪,例如“ delete”,“ addUser”,“ update”等。我能够通过“ posts”中的“ post blog”功能成功实现此目的-dashboard.component.ts”,现在我尝试使用“ student-user.component.ts”中的“删除用户”功能执行相同操作,但编译器返回错误“属性'id'不存在”输入“ void””

我尝试将id定义为'id:any;'和'id ='''但我不认为这是解决方案。错误不会消失。审计跟踪功能应该在控制台中打印输出(审计跟踪)并将审计跟踪日志存储在审计跟踪模型下的数据库中

这是我的student-user.component.ts。寻找deleteStudent(value)函数...这就是我实现它的地方

import { Component, OnInit } from '@angular/core';
import { map, catchError} from 'rxjs/operators';
import {FirebaseService} from '../services/firebase.service';
import {Router} from '@angular/router';
import { AngularFirestore} from "angularfire2/firestore";
import { Observable } from 'rxjs';
import { AuditTrailService } from 'src/app/services/audit-trail/audit-trail.service';
import { AngularFireStorage } from '@angular/fire/storage';


@Component({
  selector: 'app-student-user',
  templateUrl: './student-user.component.html',
  styleUrls: ['./student-user.component.scss']
})

export class StudentUserComponent implements OnInit{
  students: any;
  students_data :any;
  public searchString: string;
  response: any;
  is_loading: any;
  ideas; any;
  term = '';
  //id: any[];


  constructor(
    public firebaseService: FirebaseService,
    private router: Router,
    public db: AngularFirestore,
    private storage: AngularFireStorage,
    public _auditTrailService:AuditTrailService
  ) { }


 ngOnInit() {

  this.getStudents()
  this.searchStudents(event)

}


getStudents() {
  this.students_data = this.db.collection('User', ref => ref.where('role', '==', 'student')).snapshotChanges().pipe(map(changes => {

  return changes.map(a => {
  const data: any = a.payload.doc.data();
  data.id = a.payload.doc.id;
  return data;
  });
  })
  );

  this.students_data.subscribe(
  res => {
  console.log(res);
  this.students = res;
  //this.blogs_snapshot = res;
  });

  }

  searchStudents(event){
    if (event.key === "Enter"){
      console.log(this.term)
      this.db.collection('User', ref => ref.where('full_name', '==', this.term)).valueChanges().subscribe(
      res => {
      this.response = res;
      console.log(this.response);

      this.ideas = res;
      this.is_loading = false;
        }
        );
    }
  }

  deleteStudent(value){
    this.db.collection('User').doc(value).delete().then( 
      res =>{
      console.log(res)
      this.students = res;
      const _audit_trail = {
        'action' : ' has deleted a student ',
        'object': res.id,
        'created_at': new Date(),
        'user':{
          'id': '4545454545454545454',
          'email':'daanyu@gmail.com' }
         } 
      console.log(_audit_trail)

      this._auditTrailService.createAuditTrailLog(_audit_trail)

    },

    err=>{
      console.log(err)
    }
    )
  }

} 

这是我的错误...

ERROR in src/app/student-user/student-user.component.ts(87,23): error TS2339: Property 'id' does not exist on type 'void'.

我正在使用Firebase作为我的数据库,这是我希望在我的audit-trail模型下在db中返回的内容:

操作“已删除学生” created_at七月22,2019,5:49:33 PM UTC + 3 用户: 电子邮件“ daanyu@gmail.com” id“ 4545454545454545454”

1 个答案:

答案 0 :(得分:0)

我以前没有使用过Firebase,但是您的错误使我相信Firestore中的res方法不会返回成功响应,因为它暗示void的类型为this.students 。您可以根据用例使用this.responsevar $currentFocus; $(document).on("click",function(event){ $currentElement=$(":focus"); if ($(event.target).is("input")) { $currentFocus=$(event.target); return; } else{ $currentFocus.focus(); } })中的ID。