Fork me on GitHub

让前端与后端异步起来

  有时,后台处理批量数据,需要一定的时间,如果处理一部分往前台送一部分,用户体验要好一些,这样就用到这个知识点了。

后台代码中下:

 [HttpGet("/getents")]
        public async IAsyncEnumerable<Entity> GetEntitys()
        {           
            for (var i = 0; i < 20; i++)
            {
                _logger.LogInformation(i.ToString());
                await Task.Delay(RandomNumberGenerator.GetInt32(100, 500));
                yield return new Entity { ID = i, Time = DateTime.Now };
            }
        }

  前端代码,从后台取到数据后,展现在前端(我这里是拼接,用vue也可以),因为数据没有取完,所以不是一个完整的json字符串,需要在最后加上“]”

@{
  ViewData["Title"] = "Home Page";
}
<div class="text-center">
  <h1 class="display-4">实时加载</h1>
  <div id="divmessage" class="alert alert-warning" role="alert">
    <span id="message"></span>
  </div>
  <ul id="data" class="list-group">
  </ul>
</div>
@section Scripts{
<script>
  $(function() {
    var xhr=new $.ajaxSettings.xhr();  
    xhr.onreadystatechange=function(){
      if(xhr.readyState==3){
        var list=JSON.parse(xhr.responseText.replace(']','')+']');
        $("#message").html("加载中…… 【"+list.length+"】")
        var html=""
        $(list).each(function(index,item){
          html+='<li  class="list-group-item">'+item.id+"  "+item.time+"</li>"
        })
        $("#data").html(html)
      }else if(xhr.readyState==4){
        var list=JSON.parse(xhr.responseText.replace(']','')+']');
        $("#message").html("加载完成,共"+list.length+"条记录")
        $("#divmessage").removeClass("alert-warning")
        $("#divmessage").addClass("alert-success")
      }
    }
    xhr.open('GET', '/getents')
    xhr.send()
  });
</script>
}

  效果是后台处理一块,就返回一块,前台展示一块,因为这里不能放视频和动图,所以可以自行运行结果看一下(.net6),或脑补一下效果。

  想要更快更方便的了解相关知识,可以关注微信公众号 

posted @ 2022-04-27 15:00  桂素伟  阅读(98)  评论(0编辑  收藏  举报