本文實例為大家分享了js實現瀑布流效果的具體程式碼,供大家參考,具體內容如下
前端內容:
使用Javascript和四個p,將照片放入四個p中
<!DOCTYPE html> <html> <head> <meta charset="UTF-8" /> <title>Title</title> <style> .container { width: 1000px; margin: 0 auto; background-color: lightgray; } .item { width: 24%; margin-right: 10px; float: left; } .item img{ width: 100%; } </style> </head> <body> {#将内容放在container中#} <p> {# 将图片内容放入四个item中,形成四个item#} <p></p> <p></p> <p></p> <p></p> </p> <script src="/static/js/jquery-2.1.4.min.js"></script> <script> $(function() { {#网页加载时自动执行# } var obj = new ScrollImg(); obj.fetchImg(); obj.scrollEvent(); }) {#定义对象# } function ScrollImg() { this.nid = 0; {#取照片方法# } this.fetchImg = function() { var that = this $.ajax({ url: '/get_imgs.html', type: 'GET', {#传输数据,已经取了多少照片,后台可以依据,继续取照片# } data: { 'nid': that.nid }, dataType: 'JSON', success: function(args) { if (args.status) { var img_list = args.data; $.each(img_list, function(index, obj) { var eqv = that.nid % 4; var tag = document.createElement('img') tag.src = '/' + obj.img_dir; console.log(eqv) $('.container').children().eq(eqv).append(tag) that.nid += 1; }) } } }) } {#监听滚动条,当滚到底部时,自动加载数据# } this.scrollEvent = function() { var that = this; $(window).scroll(function() { var srollTop = $(window).scrollTop(); var winHeight = $(window).height(); var docHeight = $(document).height(); if (srollTop + winHeight >= docHeight - 2) { that.fetchImg(); } }) } } </script> </body> </html>
後台內容:
基於Django的FBV,函數視圖,進行資料的讀取和處理ajax請求
def get_imgs(request):
# 取得已經取得的照片數目
index = request.GET.get('nid')
#取得QuerySet集合對象,取從index後的10調資料
imgs_list = models.Student.objects.values('id','img_dir','name')[index:index+10]imgs_list = list(imgs_list)
# # 傳送狀態和資料內容
ret = { 'status':True, 'data':imgs_list}return JsonResponse(ret)
以上是使用JavaScript製作瀑布流效果的詳細內容。更多資訊請關注PHP中文網其他相關文章!