我试图减少对服务器的请求数量。我想返回部分视图到我的$.get
方法作为一个字符串,以便我可以一次返回3个,而不是有3个独立的服务器回调。无论如何要做到这一点。到目前为止,我作为字符串返回部分视图
到目前为止,它只是返回System.Web.Mvc.PartialViewResult
function updateChat() {
/** I want to make this work so I only have 1 callback */
$.get("Home/refreshChatParts", {}, function (response) {
var html = response.split(",");
$("#chatWindow").replaceWith(html[0]);
$("#chatHeader").replaceWith(html[1]);
$("#playerList").replaceWith(html[2]);
});
/** this stuff works, but is a lot of call backs */
$.get("Home/refreshChatText", {}, function (html) {
$("#chatWindow").replaceWith(html);
});
$.get("Home/refreshChatHeader", {}, function (html) {
$("#chatHeader").replaceWith(html);
});
$.get("Home/refreshPlayerList", {}, function (html) {
$("#playerList").replaceWith(html);
});
*/
$.get("Home/getRequest", {}, function (requestUser) {
if (requestUser.toString() != "failed") {
pause = true;
var join = confirm(requestUser + " would like to play a game with you");
if (join) {
startGame(requestUser);
} else
pause = false;
resetRequestUser(requestUser);
}
});
//$.get("Home/checkForGameStart", {}, function (response) { /*alert(response);*/ });
scrollChatDown();
setTimeout('updateChat()', 20000);
}
public String refreshChatParts() {
//refresh chat text
ViewData["ChatText"] = getFormatedChatText();
//refresh usercount
try {
userCount = getUserCount();
ViewData["numberOfUsers"] = "There are " + userCount + " players online";
} catch (Exception e) { ViewData["numberOfUsers"] = e.Message; }
//refresh player list
ViewData["listOfPlayers"] = getFormatedPlayerList();
checkForGameStart();
return PartialView("ChatText") + "," + PartialView("ChatHeader") + "," + PartialView("playerList");
}
@AlfalfaStrange同意了。 –