- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Nodejs、Express、MySQL、EJS。
用户能够创建帖子和评论/回复评论/回复对这些帖子的回复。
问题:我不知道如何以允许我在 EJS 中呈现它们的方式将数据分类为对象/数组。我知道如何针对评论和回复评论,但不知道如何回复回复。如何创建一个对象/数组(或多个对象/数组)来“更容易/更简单”地管理评论、回复和回复的回复(...等)?
想法:我相信最终产品应该是这样的:
“评论”MySQL 表是:
ID comment ReplyToCommentID
--------------------------------------------------------
1 | First Updated Comment | NULL
2 | Second Comment | NULL
3 | Third Comment | NULL
4 | 4th Comment | NULL
5 | This is a reply to comment ID 1 | 1
6 | Reply to Comment ID 4 | 4
7 | Testing here | NULL
8 | TriHard 7 comment id 7 | NULL
ReplyToCommentID中的值表示评论是对ID为该值的评论的回复,ID为5和6的评论是对ID为1和4的评论的回复,如果为NULL则表示是普通评论对帖子发表评论。
将它们从 MySQL 获取到 Node 以这种格式返回它们:
[{"id":1,"comment":"First Updated Comment","ReplyToCommentID":null},{"id":2,"comment":"Second Comment","ReplyToCommentID":null},{"id":3,"comment":"Third Comment","ReplyToCommentID":null},{"id":4,"comment":"4th Comment","ReplyToCommentID":null},{"id":5,"comment":"This is a reply to comment ID 1","ReplyToCommentID":1},{"id":6,"comment":"Reply to Comment ID 4","ReplyToCommentID":4},{"id":7,"comment":"Testing here","ReplyToCommentID":null},{"id":8,"comment":"TriHard 7 comment id 7","ReplyToCommentID":null}]
将评论和回复分离到它们自己的对象中可以做到这一点。 (显然)
this is replies {"1":"This is a reply to comment ID 1","4":"Reply to Comment ID 4"}
This is comments {"1":"First Updated Comment","2":"Second Comment","3":"Third Comment","4":"4th Comment","7":"Testing here","8":"TriHard 7 comment id 7"}
我花了几天时间试图解决这个问题,但对于我的“学生体验”来说似乎太过分了。 (我是自学成才,所以在现实生活中没有人可以求助)
如果你能帮助我,我将不胜感激。
感谢您的宝贵时间。
最佳答案
您目前有一个列表。但你实际上想要一个“ TreeView ”。所以把你的列表变成一棵树是有意义的。到时候我们还可以对根 Node 进行排序:
const roots = [];
const byId = new Map();
for(const reply of replies)
byId.set(reply.id, reply);
for(const reply of replies) {
const {ReplyToComment} = reply;
if(ReplyToComment) {
const parent = byId.get(ReplyToComment);
(parent.children || (parent.children = [])).push(reply);
} else {
roots.push(reply);
}
}
现在 roots
看起来像这样:
[{
id: 1,
/*...*/
children: [{
id:2,
ReplyToComment:1
}, /*...*/]
}, /*...*/ ]
然后如何将它呈现到您的页面是您的事情,但是递归方法看起来像:
function show(replies, depth = 0) {
for(const reply of replies) {
console.log(" ".repeat(depth) + reply.comment);
show(reply.children || [], depth + 1);
}
}
show(roots);
现在控制台输出将是
comment
reply
reply
reply
...
html也可以采用类似的东西。
关于javascript - 如何正确排序我的评论/回复/对回复数据的回复,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49477491/
我有多个 InOut 模式的顺序队列,每个队列通向一个 Camel 处理器。如果处理器花费太多时间进行处理,我希望请求-答复检测到超时并发送 ExchangeTimedOutException。Cam
我是一名学生,试图了解更多关于 C# 中的 ARP 和套接字的信息 为此,我尝试使用原始 Socket 发送 ARP 请求和回复。在 C# 中。 我已经在一个字节数组中手动重建了一个 ARP 回复
我正在使用 Amazon Web Services 数据库 dynamodb。它返回一个 JSON,看起来像这样: {"Responses":{"friends":[{"to_username":"u
我有 servlet,它创建 html 文件,然后将其转换为 pdf 文件: private void ConvertHTMLtoPDF(String sConvertationProgramm, S
我正在为我的项目使用 Mailkit 库 (Imap)。 我可以轻松地通过 SmtpClient 发送新消息。 目前我正在研究如何回复特定邮件。是否可以向该回复邮件添加更多收件人? @jstedfas
这个问题已经有答案了: How to parse JSON in Java (36 个回答) 已关闭 7 年前。 请您告诉我如何解析 JSON 回复。我从 https://api.privatbank
我正在尝试从事 YouTube 视频评级工作。但我被困在这里了。这两个 YouTube 评级请求有什么区别? https://www.googleapis.com/youtube/v3/videos/
我搜索了该网站,令人惊讶的是没有找到任何适合我情况的答案。所以我发布了这个问题。 我正在使用 jQuery AJAX 来获取网页并将其动态添加到网站。但我的代码不起作用并抛出错误 ERROR Type
我正在编写一个 C 程序来搜索本地网络上的 smb 共享并安装它们。为了获取找到的 smb 服务器的主机名,我向服务器发送了 udp nbns 数据包。数据包正确,服务器回复。我正在使用wiresha
我正在尝试使用 Java 创建自己的 WebSocket 服务器。 当我的客户端连接时,我收到以下请求: (14): GET / HTTP/1.1 (18): Upgrade: WebSocket (
我正在使用 Nodejs、Express、MySQL、EJS。 用户能够创建帖子和评论/回复评论/回复对这些帖子的回复。 问题:我不知道如何以允许我在 EJS 中呈现它们的方式将数据分类为对象/数组。
我正在用 .NET c++ 编写程序。我正在本地网络上发送广播 ping。我的所有目标设备都能够响应 ping 广播,事实上我在 Wireshark 中跟踪了它们的所有响应。我的目标是检索所有响应站点
我有一个向 JMS MDB 发送请求的客户端。它可以很好地向 MDB 发送消息,但我一辈子都无法弄清楚如何让客户端接收 MDB 发回给它的响应。 编辑:客户端代码是同一实例上的 Web 服务,使用 @
我使用钩子(Hook)函数制作了一个模块。它可以工作,但是当我使用 ping google.com 时,我得到 0045 作为 icmp 类型。但我认为它应该是 0 用于回显回复。我使用了以下打印命令
我正在用 C 从头开始编写一个网络库。我已经实现了以太网协议(protocol),现在我想让 ARP 工作。发送请求/回复工作正常,但接收工作不正常。当我发送一个发送请求并等待它之后的回复时,re
我在替换字符串的一部分时遇到问题。现在这段代码。我的目标是针对包含此字典中的键的每个字符串。 mapping = { "St": "Street", "St.": "Stree
我有一个 WCF p2p 网状网络,它运行良好,适合单向对话。我正在研究是否可以调用一种方法来添加两个数字并返回和总和。 但是我在尝试连接时遇到错误: 契约(Contract)需要请求/回复,但绑定(
大家好,我正在尝试使用分块编码流式传输多媒体数据。因此,我首先尝试使用分块编码发送文本数据。 这是我的代码。我创建了一个服务器套接字,我在上面监听请求(端口 80),回复请求,然后我的程序终止。无论您
我的 Servlet 中有一些图像,我想将它们下载到我的 Android 应用中。 我正在对这个 URL 执行一个 GET 请求: public static final String URL ="h
文档:https://developers.google.com/apps-script/reference/gmail/gmail-message#replybody-options 当跟进一封电子
我是一名优秀的程序员,十分优秀!