ASP.NET Core MVC 中的容器(例如列表或表格)可能需要在一个页面上动态更新,以反映从服务器收到的最新数据。但是,该容器可能会包含用户已经添加或修改的数据,而这些数据需要保留。
下面是一种解决该问题的方法,通过在服务器端将数据与客户端提交的数据进行比较来保留原始数据,并进行必要的更新。
1.创建一个服务器端方法,用于比较容器中的数据:
private void UpdateContainer(List originalData, List updatedData)
{
foreach (var originalItem in originalData)
{
var updatedItem = updatedData.FirstOrDefault(x => x.Id == originalItem.Id);
if (updatedItem != null)
{
// update originalItem with updatedItem's data
}
}
}
2.在客户端使用 AJAX 或 SignalR 将更新发送到服务器。服务器将更新数据与原始数据进行比较,并保留原始数据。
$.ajax({
url: "/SomeController/UpdateContainer",
method: "POST",
data: JSON.stringify(updatedData),
contentType: "application/json; charset=utf-8"
}).done(function (response) {
// handle response from server
});
// OR using SignalR
connection.invoke("UpdateContainer", updatedData).catch(function (error) {
// handle error
});
3.在服务器端的控制器中调用更新方法。
[HttpPost]
public IActionResult UpdateContainer(List updatedData)
{
var originalData = // get original data from database
UpdateContainer(originalData, updatedData);
// save changes to database
return Ok();
}
通过这种方法,容器中的数据可以根据来自服务器的动态更新进行更新,同时保留用户已添加或修改的数据。