【发布时间】:2018-12-17 19:51:06
【问题描述】:
我正在基于 Microsoft-Tutorial for SignalR 和 JavaScript 构建一个小型 ChatHub 应用程序。
简而言之:中心消息放在按需创建 (li) 中
出于样式目的,我希望为这些 (li) 添加一个类名,将它们区分为“发送者”和“接收者”类别
背景: ChatConnection 的每一侧都有不同的视图。我仍在建立短信的逻辑,所以这远非完美无缺。
我的friendstable dbo 是UserFriends,根据您是友谊的哪一方,您会得到一个不同(但镜像的)聊天窗口。
cshtml-sn-p:
@foreach (var item in Model.UserFriends)
{
@if (item.FriendChatName == @User.Identity.Name)
{
<div>
<button class="open-button" onclick="openChatForm()">@item.UserChatName</button>
<div class="chat-popup" id="myChatForm" style="display:none">
<form action="/action_page.php" class="form-container">
<button type="button" class="btn cancel" onclick="closeChatForm()">@item.UserChatName</button>
<input type="hidden" id="receiverInput" value="@item.UserChatName"/>
<ul id="messagesList" class="chatmessage receiver" ></ul>
<input type="hidden" id="userInput" class="receiverInput" value="@item.FriendChatName" />
<textarea placeholder="Type message.." required style="height:32px;" id="messageInput"></textarea>
<button type="submit" asp-route-user="@User.Identity.Name" asp-route-sender="@User.Identity.Name" asp-route-receiver="@item.UserChatName" class="btn" id="sendButton">Send</button>
</form>
</div>
</div>
}
@if (item.UserChatName == @User.Identity.Name)
{
<div>
<button class="open-button" onclick="openChatForm()">@item.FriendChatName</button>
<div class="chat-popup" id="myChatForm" style="display:none">
<form action="/action_page.php" class="form-container">
<button type="button" class="btn cancel" onclick="closeChatForm()">@item.FriendChatName</button>
<input type="hidden" id="receiverInput" value="@item.FriendChatName" />
<ul id="messagesList" class="chatmessage sender" ></ul>
<input type="hidden" id="userInput" value="@item.UserChatName" />
<textarea placeholder="Type message.." required style="height:32px;" id="messageInput"></textarea>
<button type="submit" asp-area="" asp-route-user="@User.Identity.Name" asp-route-sender="@User.Identity.Name" asp-route-receiver="@item.FriendChatName" class="btn" id="sendButton">Send</button>
</form>
</div>
</div>
}
}
ChatHub 类:
public class ChatHub : Hub
{
public async Task SendMessage(string user, string message)
{
await Clients.All.SendAsync("ReceiveMessage", user, message);
}
}
还有 chat.js 脚本-sn-p:
var connection = new signalR.HubConnectionBuilder().withUrl("/chatHub").build();
connection.on("ReceiveMessage", function (user, message) {
var msg = message.replace(/&/g, "&").replace(/</g, "<").replace(/>/g, ">");
var encodedMsg = user + ": " + msg;
var li = document.createElement("li");
li.textContent = encodedMsg;
document.getElementById("messagesList").appendChild(li);
});
connection.start().catch(function (err) {
return console.error(err.toString());
});
document.getElementById("sendButton").addEventListener("click", function (event) {
var user = document.getElementById("userInput").value;
var message = document.getElementById("messageInput").value;
connection.invoke("SendMessage", user, message).catch(function (err) {
return console.error(err.toString());
});
event.preventDefault();
});
我正在尝试得到这种东西:
if (user == reciever ) {
li.className = "receiver";
}
if (user == sender) {
li.className = "sender";
}
借助这个sn-p
var sender = document.getElementById("senderInput").value;
var receiver = document.getElementById("receiverInput").value;
但是当所有的东西都变平后,我只得到一个运行时错误
这是两个浏览器窗口中的视图
任何人都可以帮助我在 chat.Js 中构建 If 或有其他关于我将如何以不同方式设置 sendermessenges 和 receivermessages 的结构注释,将不胜感激!
【问题讨论】:
标签: javascript css asp.net-core-mvc signalr chat