所以我尝试上传图片到防火墙存储,并将其添加到具有名称和存储url的实时数据库中。我将删除我在这里遇到问题的代码片段。我认为是什么导致了错误消息:错误: Reference.set失败:第一个参数包含属性'Pictures.KULT.Link‘中未定义的参数(KULT将是ImgName)。我想知道我具体做错了什么,以及如何修复它?
ImgName = document.getElementById('namebox').value;
var uploadTask = firebase.storage().ref("Images/"+ImgName+".png").put(files[0]);
uploadTask.on("state_changed", function(snapshot){
var progess = (snapshot.bytesTransferred / snapshot.totalBytes)*100;
document.getElementById('upProgress').innerHTML = "Upload "+progess+"%";
},
function(error){
alert("Det oppsto en feil.")
},
function() {
uploadTask.snapshot.ref.getDownloadURL().then(function(url){
ImgUrl = url;
});
**firebase.database().ref("Pictures/"+ImgName).set({
Name: ImgName,
Link: ImgUrl
});**
alert("Bildet er lastet opp.");
});
}```
really appericiate any help <3发布于 2021-05-28 00:34:28
我相信您的问题是,您只在完成ImgUrl函数之后才设置getDownloadUrl:
uploadTask.snapshot.ref.getDownloadURL().then(function(url){
ImgUrl = url;
});...but是异步的,所以在您调用set之后才会发生。在进行调用时,ImgUrl变量将未定义,因此出现错误消息。
例如,您可以通过将整个set调用移动到getDownloadUrl()承诺的处理程序中来解决这个问题,如下所示:
function() {
uploadTask.snapshot.ref.getDownloadURL().then(function(url){
ImgUrl = url;
firebase.database().ref("Pictures/"+ImgName).set({
Name: ImgName,
Link: ImgUrl
});
alert("Bildet er lastet opp.");
});
});https://stackoverflow.com/questions/67730905
复制相似问题