我想根据演示图像在foreach循环中一个一个地显示值

I want to display one by one value in foreah loop according to demo Image

在一个有 180 条记录的模型中,我想一次显示一条。当我单击下一个按钮时,下一条记录将显示为刷新页面。

您可以尝试使用 TempData 和部分视图,这里是一个演示:

型号:

public class LoopModel{
       public List<string> l { get; set; }
        public int count { get; set; }
    }

操作:

[HttpGet]
        public IActionResult TestLoop()
        {
            
            LoopModel loopModel = new LoopModel { l = new List<string> { "s1", "s2", "s3", "s4", "s5" }, count = 0 };
           TempData["model"] =JsonConvert.SerializeObject(loopModel);
            return View();
        }
        [HttpPost]
        public IActionResult TestLoop(int count)
        {
            var s = TempData.Peek("model").ToString();
            LoopModel loopModel = JsonConvert.DeserializeObject<LoopModel>(TempData.Peek("model").ToString());
            if(count<loopModel.l.Count())
            loopModel.count = count;
            return PartialView("Partial1",loopModel);
        }

TestLoop.cshtml:

@using Newtonsoft.Json;
<div id="myDiv">
    @await Html.PartialAsync("Partial1", JsonConvert.DeserializeObject<LoopModel>(TempData.Peek("model").ToString()))
</div>
<button onclick="AddContent()">next</button>
@section Scripts
{
    <script>
        var count = 0;


        function AddContent() {
            count++;
            $.ajax({
                type: "POST",
                url: '?count=' + count,
                success: function (result) {
                    $("#myDiv").html(result);
                }
            });
    }
    </script>
}

部分 1:

@model LoopModel
@for (var i = 0; i <= Model.count; i++)
{
    <div class="container">@Model.l[i]</div>
}

结果: