gpt4 book ai didi

node.js - 尝试将新变量推送到数组时出现 "userIDs.push is not a function"

转载 作者:太空宇宙 更新时间:2023-11-03 23:54:23 26 4
gpt4 key购买 nike

我很难理解我做错了什么。我来自 Android 世界,那里的一切都简单得多...无论如何,我有一个函数可以检查我想要更新的 firebase 数据库表是否存在,如果不存在,它会创建一个。到目前为止一切都很好,问题是创建表后我想随后更新它的内容,并且我在理解为什么无法更新我创建的数组时遇到问题。

这是我的代码 -

enter image description here

正如我所说,我在推送到数组时遇到问题。在 firebase 控制台日志中,我收到以下错误 -

enter image description here

据我所知,数组有“.push”方法。那么我做错了什么?

编辑-

这是我的数据库的样子。显然,我持有两个变量,而不是我想要的一个变量和一个列表。我希望 userUID 成为一个列表 -

enter image description here

编辑-

这是我的代码 -


function createOrUpdateDeletedVideosTable(profileUid, response) {

const deletedVideosRef = database.ref(config.ENTITY_NAME_DELETED_VIDEOS);
return deletedVideosRef.once("value").then(deletedVideosSnapshot => {
var snapshotValue = JSON.stringify(deletedVideosSnapshot);
console.log("snapshot value is null - " + snapshotValue !== "null")
console.log("snapshot value is null - " + snapshotValue !== null)
if (snapshotValue !== "null") {
console.log("deleted videos ref exists - " + JSON.stringify(deletedVideosSnapshot));
var deletedVideosVar = deletedVideosSnapshot.val();
console.log(JSON.stringify(deletedVideosVar))
deletedVideosVar["totalVideosDeleted"] = deletedVideosVar.totalVideosDeleted += 1
deletedVideosVar.userUIDs.push(profileUid);
deletedVideosRef.set(deletedVideosVar);
return response.status(200).send('{"result": "OK"}');
}
console.log("deleted videos ref does not exist")
return createDeletedVideosTable(profileUid, response);
}).catch(err => {
console.log(err);
return response.status(500).send(`deleted video counter error - ${err}`);
});
}

function createDeletedVideosTable(profileId, response) {
var deletedVideosVar = {
totalVideosDeleted : 1,
userUIDs : {
profileId
}
};
// deletedVideosVar.totalVideosDeleted = 1
// deletedVideosVar.userUIDs.push(profileId);
database.ref(config.ENTITY_NAME_DELETED_VIDEOS).set(deletedVideosVar);
return response.status(200).send('{"result": "OK"}');
}


最佳答案

这很可能是因为 deletedVideosVar["usersUIDs"] 不是数组。

通过执行 deletedVideosVar["usersUIDs"],您将使用方括号表示法访问 deletedVideosVar 对象的 usersUIDs 属性,请参阅 https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Property_accessors

如实时数据库中所述 doc ,“根据 DataSnapshot 中的数据,val() 方法可能返回标量类型(字符串、数字或 bool 值)、数组或对象”。

如果您分享数据库的结构,我们可能会确认 deletedVideosVar["usersUIDs"] 不是数组的假设。

<小时/>

更新您的评论:

以下代码将更新实时数据库 Node ,该 Node 是具有新值的数组。请注意,使用实时数据库,您需要首先读取现有数组,然后推送一个值并重写整个数组。

  var db = firebase.database();
var myRef = db.ref('myRef');

myRef.once('value').then(function(snapshot) {
//Let's create a random value for this example
var random = Math.floor(Math.random() * 500 + 1);

if (snapshot.exists()) {

var newArray = snapshot.val().array;
newArray.push('A' + random);

var postData = {
array: newArray
};

var updates = {};
updates['myRef'] = postData;
db.ref().update(updates);
} else {
var postData = {
array: ['A' + random]
};

myRef.set(postData);
}
});
<小时/>

对于 deletedVideosVar.totalVideosDeleted 的增量,您可能应该使用事务,请参阅 https://firebase.google.com/docs/database/web/read-and-write?authuser=0#save_data_as_transactions

关于node.js - 尝试将新变量推送到数组时出现 "userIDs.push is not a function",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58016389/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com