gpt4 book ai didi

javascript - 如何在Parse上保存具有不同ACL的Parse对象的指针?

转载 作者:行者123 更新时间:2023-11-27 23:48:34 27 4
gpt4 key购买 nike

我这里有一个非常棘手的问题;我现在至少查看了 Parse.com js SDK 三遍,但无法弄清楚这一点。

我有一个包含文本、用户、评论的问题类。我有一个带有文本的评论类,用户。

注释放置在指向问题类的指针数组中。

Question = Parse.Object.extend('Question');
question = new Question();
question.set('text', 'my first question');

// the user posting the question
var acl = new Parse.ACL(Parse.User.current());
acl.setPublicReadAccess(true);
question.setACL(acl);
question.set('user', Parse.User.current());
question.save();

这里一切都很好。现在,另一个用户登录应用程序并发表评论

question; // let's asume the question is fetched
Comment = Parse.Object.extend('Comment');
comment = new Comment();
comment.set('text', 'my first comment on the first question');

// the user posting the comment (another user)
// this user has public read rights on the comment but not write rights
// he has the write rights on his comment though

var acl = new Parse.ACL(Parse.User.current());
acl.setPublicReadAccess(true);
comment.setACL(acl);
comment.set('user', Parse.User.current());
comment.save();

// comment is saved we can now add it to the question's array
question.add(comment);
question.save(); // this is where everything fails...

它说用户无权在问题对象上书写,这是正常的,但是如果我不使用新数组保存问题,如何保存评论?

最佳答案

选项 1:加入表

question; // let's asume the question is fetched

//GET OBJECT ID HERE WHEN FETCHING QUESTION
questionID = question.id;


Comment = Parse.Object.extend('Comment');
comment = new Comment();
comment.set('text', 'my first comment on the first question');

// the user posting the comment (another user)
// this user is have public read rights on the comment but not write rights
// he has the write rights on his comment though

var acl = new Parse.ACL(Parse.User.current());
acl.setPublicReadAccess(true);
comment.setACL(acl);
comment.set('user', Parse.User.current());

//NEW CODE HERE TOO
comment.save().then(function(results){
commentID = results.id;
});;

// NOW ADD COMMENT AND QUESTION TO JOIN TABLE BY OBJECTID
JoinTable = Parse.Object.extend('JoinTable');
entry = new JoinTable();
entry.set('questionID', questionID);
entry.set('commentID', commentID);
entry.save().then(function(results){
//MIGHT WANT TO PUSH THE NEW COMMENT ONTO THE COMMENTS ARRAY
//WHICH YOU ARE DISPLAYING WITH YOUR QUESTION
});

现在,当您加载问题时,只需通过 QuestionID 对连接表进行查询,这将为您提供与该问题关联的所有 commentID。然后使用该 commentID 查询评论表,加载并显示这些结果。

选项 2:保存带有评论的问题 ID

question; // let's asume the question is fetched

//GET OBJECT ID HERE WHEN FETCHING QUESTION
questionID = question.id;


Comment = Parse.Object.extend('Comment');
comment = new Comment();
comment.set('text', 'my first comment on the first question');

// the user posting the comment (another user)
// this user is have public read rights on the comment but not write rights
// he has the write rights on his comment though

var acl = new Parse.ACL(Parse.User.current());
acl.setPublicReadAccess(true);
comment.setACL(acl);
comment.set('user', Parse.User.current());
//SET QUESTION ID ON COMMENT
comment.set('parent', questionID);


//NEW CODE HERE TOO
comment.save().then(function(results){
commentID = results.id;
});;

现在,当您查询问题时,还可以查询评论表并检索以当前问题 objectID 作为“父级”的所有评论。

您在评论中提到

该解析不是关系性的。 Parse 基于 MongoDB,它是一个 NoSQL 数据库。但是,您可以“通过引用”建立关系。

http://docs.mongodb.org/manual/core/data-modeling-introduction/

检索问题和评论

//First get the question
var Question = Parse.Object.extend("Question");
var query = new Parse.Query(Question);
query.equalTo("questionID", questionID);
query.find({
success: function(results) {
//You will have to check results and see if it returns an array
//If it does you will need to use results[0].id to select 1st
//element in array. The follow code is if results is an Object

var JoinTable = Parse.Object.extend("JoinTable");
var query = new Parse.Query(JoinTable);
query.equalTo("parentID", questionID);
query.find({
success: function(results) {
//this should return an array, loop through the array to get
//all of the IDs then, pe## Heading ##rform a compound query with all of
//IDs

},
error: function(error) {
alert("Error: " + error.code + " " + error.message);
}
});
},
error: function(error) {
alert("Error: " + error.code + " " + error.message);
}
});

但是,编写该代码非常烦人且没有必要,因此我在这里推荐选项二,说明如何做到这一点

//First get the question
var Question = Parse.Object.extend("Question");
var query = new Parse.Query(Question);
query.equalTo("questionID", questionID);
query.find({
success: function(results) {
//You will have to check results and see if it returns an array
//If it does you will need to use results[0].id to select 1st
//element in array. The follow code is if results is an Object

var questionID = results.id;

var Comments = Parse.Object.extend("Comments");
var query = new Parse.Query(Comments);
query.equalTo("parentID", questionID);
query.find({
success: function(results) {
//This returns your comments to be shared with your view

},
error: function(error) {
alert("Error: " + error.code + " " + error.message);
}
});
},
error: function(error) {
alert("Error: " + error.code + " " + error.message);
}
});

您会注意到,我停止在 commentID 上的 forEach 循环中编写实际代码,因为我意识到这是多么不必要。希望这会有所帮助。

关于javascript - 如何在Parse上保存具有不同ACL的Parse对象的指针?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32928946/

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