2016-03-30 4 views
0

Я столкнулся с небольшим вопросом с огненной базой и угловым2. Я загружаю небольшую задачу, и пользователи могут обращаться к ним.изменение моментального снимка и угловой замены фонаря2

loadTask() { 
    let post = [] 
    const publicationRef = this.rootRef.child('task').child('attente'); 
    const usersR = this.rootRef.child('users') 
return Observable.create((observer) => { 
    this.geoQuery.on("key_entered", function(key, location, distance){ 
    publicationRef.child(key).on('value', snapshot => { 
     const taskkey = snapshot.key() 
     snapshot.forEach((data) => { 
     const datakey = data.key(); 
     const dataVal = data.val(); 
     usersR.orderByKey().equalTo(dataVal.user).on('child_added', snapshot => { 
      console.log({key: datakey,nom: snapshot.val().nom, distances: distance}) 
      post.push({nom: dataVal.nom, key: datakey,unom: snapshot.val().nom, uprenom: snapshot.val().prenom, distance: Math.floor(distance), uimage:snapshot.val().image, budget: dataVal.budget, description: dataVal.description, date:dataVal.date, location: dataVal.location, user: dataVal.user, id1: taskkey, id:datakey}) 
      observer.next(post) 
     }) 
     }) 
    }) 
    }) 
}) 
} 

все задачи отображаются, но когда я применить к задаче, в йот его называют новый метод нажимной, поэтому новую задачу с тем же значением появляется и disseapear когда я перезагрузите страницу. я попытался удалить метод нажимного

loadTask() { 
    const publicationRef = this.rootRef.child('task').child('attente'); 
    const usersR = this.rootRef.child('users') 
return Observable.create((observer) => { 
    this.geoQuery.on("key_entered", function(key, location, distance){ 
    publicationRef.child(key).on('value', snapshot => { 
     const taskkey = snapshot.key() 
     snapshot.forEach((data) => { 
     const datakey = data.key(); 
     const dataVal = data.val(); 
     usersR.orderByKey().equalTo(dataVal.user).on('child_added', snapshot => { 
      console.log({key: datakey,nom: snapshot.val().nom, distances: distance}) 
      const publicio = [{nom: dataVal.nom, key: datakey,unom: snapshot.val().nom, uprenom: snapshot.val().prenom, distance: Math.floor(distance), uimage:snapshot.val().image, budget: dataVal.budget, description: dataVal.description, date:dataVal.date, location: dataVal.location, user: dataVal.user, id1: taskkey, id:datakey}] 
      observer.next(publicio) 
     }) 
     }) 
    }) 
    }) 
}) 
} 

применить к задаче оленьей кожи добавить новые данные с тем же значением, но в йоте это загрузить только один набор данных, и не все из них

ответ

0

Попробуйте ясно сообщение в методе «включено»:

publicationRef.child(key).on('value', snapshot => { 
    post = []; 
    const taskkey = snapshot.key(); 
    . 
    . 
    . 
+0

hi adem благодарит вас за вас anwser, я уже пробовал, не работает – PrinceZee

Смежные вопросы