当我向名为' leerling'的子节点添加opmerking
时使用.push()
,实际上添加了新节点没有问题,但是在此过程中无意中替换了现有的opmerking
节点。
之前我遇到过类似的问题,请参阅帖子Firebase push doesn't add but replace (JavaScript)然后解决,但该解决方案并不适用于此。
Here是完整源代码的小提琴。请将firebase数据库名称更改为您自己的(或者是否有可用的测试/演示数据库?)以进行测试。
$(document).ready(function(){
$("#submit").click(function(){
var _leerling = $("#Leerling").val();
var _opmerking = $("#Opmerking").val();
var _bestanden = $("#Bestanden").val();
var _door = $("#Door").val();
var success = true;
if(
_leerling == "Maak een keuze..." || _leerling == "" || _leerling == "5H:" || _leerling == "6V:" ||
_opmerking == "Typ hier jouw opmerking over de leerling die je geselecteerd hebt." || _opmerking == "" ||
_door == "Maak een keuze..." || _door == ""
) {
alert("Alle velden met * zijn verplicht");
}
else {
event.preventDefault();
var ref = new Firebase("https://torrid-inferno-6428.firebaseio.com/");
var leerlingNummer = _leerling.substring(0,6).trim();
var updatedObj = {}; // truc om key een waarde te geven, kan niet rechtstreeks met JavaScript
updatedObj[leerlingNummer] = {
"naam": _leerling.substring(7,33).trim(),
"klas": _leerling.substring(34,38),
"klaskort": _leerling.substring(35,37),
"leerlingdropdown": _leerling};
ref.child("leerling").update(updatedObj,
function(data) {
if (data) { alert(data); success = false; }
});
ref.child("leerling").child(leerlingNummer).child("opmerkingen").push({
"opmerking": _opmerking,
"bestanden": _bestanden,
"door": _door},
function(data) {
if (data) { alert(data); success = false; }
if (success) {
alert("Bedankt! Jouw opmerking is opgeslagen.");
$('#form')[0].reset(); //To reset form fields
}
});
}
});
});
答案 0 :(得分:4)
问题不在Firebase.push()
,但在这里:
var updatedObj = {}; // truc om key een waarde te geven, kan niet rechtstreeks met JavaScript
updatedObj[leerlingNummer] = {
"naam": _leerling.substring(7,33).trim(),
"klas": _leerling.substring(34,38),
"klaskort": _leerling.substring(35,37),
"leerlingdropdown": _leerling};
ref.child("leerling").update(updatedObj,
function(data) {
if (data) { alert(data); success = false; }
});
您正在更新/leerling/<leerlingNummer>
,这意味着不会更改/leerling
的其他子项。但是,您要替换/leerling/<leerlingNummer>
下的所有内容,以及删除opmerkingen
的内容。
请改为尝试:
var updatedObj = {
"naam": _leerling.substring(7,33).trim(),
"klas": _leerling.substring(34,38),
"klaskort": _leerling.substring(35,37),
"leerlingdropdown": _leerling};
ref.child("leerling").child(leerlingNummer).update(updatedObj, function(data) {
if (data) { alert(data); success = false; }
});
这将更新/leerling/<leerlingNummer>
。