zoukankan      html  css  js  c++  java
  • Java Web SpringMVC AJAX,实现页面懒加载数据

    因为做的微信端的网页,所以在显示后台数据的时候,要么分页,要么全部加载数据,开始分页对于用户来说,其实体验不是很好,毕竟要去不断的点击下一页,但是如果我把全部数据读取出来的话,但用户可能也就看前面几条而已,那么就会造成性能的大大浪费。

    所以我就上网找了ajax懒加载方面的内容,成功实现了,在用户滚动的时候判断是否到达页面底部,是的话就通过ajax请求数据,然后显示出来。

    javascript代码

    <script type="text/javascript">
    $(function() {
    	// 记录页数
    	var $page = 1;
    	// 懒加载
    	var winH = $(window).height(); //页面可视区域高度
    	$(window).scroll(function () { 
    	    var pageH = $(document.body).height(); 
    	    var scrollT = $(window).scrollTop(); //滚动条top 
    	    var aa = (pageH-winH-scrollT)/winH;
    	    if(aa<0.02){
    	    	$page++;
    	    	$.ajax({
    	    		type : "get",
    	    		url : "<c:url value='/getdata/" + $page + "' />",
    	    		dataType : "json",
    	    		success : function(data) {
    	    			if (data) {
    	    				$.each(data,function(index,array){ 
    	    		            $comment += "<li><div id="index_list_user">"; 
    	    		            $comment += "		<div id="index_list_user_wx">"; 
    	    		            $comment += "		<img src="" + array['avatar']  + "" >"; 
    	    		            $comment += "		<span>" + array['author'] + "</span>"; 
    	    		            $comment += "		</div>"; 
    	    		            $comment += "		<span id="index_list_user_bookName">《" + array['book']['title'] + "》</span>"; 
    	    		            $comment += "	</div>"; 
    	    		            $comment += "	<div id="index_list_content">"; 
    	    		            $comment += "	<span>" + array['content'] + "</span>";
    	    		           $comment += "	</div>";
    	    		           $comment += "	</li>";
    	    		           $(".index_list").append($comment); // 把上面的html添加到要显示的标签上
    	    		          }); 
    	    			}
    	    		}
    	    	});
    	    } 
    	  }); 
    });
    </script>
    

    java代码

    @RequestMapping(value = "/getdata/{page}", method = GET)
    @ResponseBody
    public List<Comment> indexPage(
    		@PathVariable int page) {
    	        page--;
    		page = page < 0 ? 0 : page;
    		List<Comment> bookComments = rmbookCommentService.getToIndexByLimit(
    				page*ReadMeetInitParameters.getCountPerPage(), ReadMeetInitParameters.getCountPerPage());
    
    		return bookComments;
    }
    

    在Java代码上转换JSON的时候可能会有问题,我参考的解决方案:http://blog.csdn.net/kinginblue/article/details/51236938

    参考地址:http://www.jb51.net/article/65073.htm

  • 相关阅读:
    Spring Boot第四弹,一文教你如何无感知切换日志框架?
    Spring Boot 第三弹,一文带你了解日志如何配置?
    UVa 1625
    UVa 11584
    UVa 11400
    UVa 12563
    UVa 116
    UVa 1347
    UVa 437
    UVa 1025
  • 原文地址:https://www.cnblogs.com/sevenun/p/6502037.html
Copyright © 2011-2022 走看看