Laravel 简单实现Ajax滚动加载示例


Posted in PHP onOctober 22, 2019

开发H5项目的时候我们总是需要用到下拉滚动刷新的方式加载页面。这里用 Laravel 实现一下,直接上代码:

创建模型

这里我们不妨创建一个 文章(Post)模型, 并且生成测试数据 50 条吧。

php artisan make:model -m

模型Post.php

namespace App;

use Illuminate\Database\Eloquent\Model;

class Post extends Model
{

 public $fillable = ['title','description'];

 
}

迁移文件

use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class CreatePostTable extends Migration
{
 /**
  * Run the migrations.
  *
  * @return void
  */
 public function up()
 {
  Schema::create('posts', function (Blueprint $table) {
   $table->increments('id');
   $table->string('title');
   $table->text('description');
   $table->timestamps();
  });
 }

 /**
  * Reverse the migrations.
  *
  * @return void
  */
 public function down()
 {
  Schema::drop("posts");
 }
}

测试数据 ModelFactory.php

$factory->define(App\Post::class, function (Faker\Generator $faker) {
 return [
  'title' => $faker->sentence,
  'description' => $faker->paragraph,
 ];
});

填充

<?php

use Illuminate\Database\Seeder;

class DatabaseSeeder extends Seeder
{
 /**
  * Run the database seeds.
  *
  * @return void
  */
 public function run()
 {
  // $this->call(UsersTableSeeder::class);
  factory(App\Post::class, 50)->create();
 }
}

路由

Route::get('my-post', 'PostController@myPost');

控制器

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Requests;
use App\Post;

class PostController extends Controller
{

 public function myPost(Request $request)
 {
  $posts = Post::paginate(6); 

  if ($request->ajax()) {
   $view = view('data',compact('posts'))->render();
   return response()->json(['html'=>$view]);
  }

  return view('my-post',compact('posts'));
 }

}

视图文件 resources/view/my-post.php

<!DOCTYPE html>
<html>
<head>
 <title>Laravel 分页滚动加载</title>
 <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
 <link href="http://libs.baidu.com/bootstrap/3.0.3/css/bootstrap.min.css" rel="external nofollow" rel="stylesheet">
 <style type="text/css">
  .ajax-load{
   background: #e1e1e1;
   padding: 10px 0px;
   width: 100%;
  }
 </style>
</head>
<body>

<div class="container">
 <h2 class="text-center">Laravel 分页滚动加载</h2>
 <br/>
 <div class="col-md-12" id="post-data">
  @include('data')
 </div>
</div>

<div class="ajax-load text-center" style="display:none">
 <p>![](./loader.gif)加载更多……</p>
</div>

<script type="text/javascript">
 var page = 1;
 $(window).scroll(function() {
  if($(window).scrollTop() + $(window).height() + 1>= $(document).height()) {
   page++;
   loadMoreData(page);
  }
 });

 function loadMoreData(page){
  $.ajax(
   {
    url: '?page=' + page,
    type: "get",
    beforeSend: function()
    {
     $('.ajax-load').show();
    }
   })
   .done(function(data)
   {
    //console.log(data.html);
    if(data.html == " "){
     $('.ajax-load').html("没有数据了……");
     return;
    }
    $('.ajax-load').hide();
    $("#post-data").append(data.html);
   })
   .fail(function(jqXHR, ajaxOptions, thrownError)
   {
    alert('服务未响应……');
   });
 }
</script>

</body>
</html>

resources/view/data.php

@foreach($posts as $post)
<div>
 <h3><a href="">{{ $post->title }}</a></h3>
 <p>{{ str_limit($post->description, 400) }}</p>

 <div class="text-right">
  <button class="btn btn-success">Read More</button>
 </div>

 <hr style="margin-top:5px;">
</div>
@endforeach

效果:

Laravel 简单实现Ajax滚动加载示例

以上这篇Laravel 简单实现Ajax滚动加载示例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
ThinkPHP中实例Model方法的区别说明
Aug 21 PHP
可以保证单词完整性的PHP英文字符串截取代码分享
Jul 15 PHP
php批量删除cookie的简单实现方法
Jan 26 PHP
PHP概率计算函数汇总
Sep 13 PHP
HTML中嵌入PHP的简单方法
Feb 16 PHP
ThinkPHP中where()使用方法详解
Apr 19 PHP
完美解决phpdoc导出文档中@package的warning及Error的错误
May 17 PHP
用php+ajax新建流程(请假、进货、出货等)
Jun 11 PHP
PHP基于PDO调用sqlserver存储过程通用方法【基于Yii框架】
Oct 07 PHP
PHP实现压缩图片尺寸并转为jpg格式的方法示例
May 10 PHP
PHP实现从PostgreSQL数据库检索数据分页显示及根据条件查找数据示例
Jun 09 PHP
PHP 图片合成、仿微信群头像的方法示例
Oct 25 PHP
Laravel 在views中加载公共页面的实现代码
Oct 22 #PHP
laravel添加前台跳转成功页面示例
Oct 22 #PHP
Laravel 实现Controller向blade前台模板赋值的四种方式小结
Oct 22 #PHP
laravel框架如何设置公共头和公共尾
Oct 22 #PHP
laravel 实现向公共模板中传值 (view composer)
Oct 22 #PHP
浅谈laravel数据库查询返回的数据形式
Oct 21 #PHP
在laravel中实现将查询的对象转换为多维数组的函数
Oct 21 #PHP
You might like
php连接mysql数据库代码
2009/03/10 PHP
ThinkPHP模板中判断volist循环的最后一条记录的验证方法
2014/07/01 PHP
javascript 特殊字符串
2009/02/25 Javascript
laytpl 精致巧妙的JavaScript模板引擎
2014/08/29 Javascript
JQuery控制div外点击隐藏而div内点击不会隐藏的方法
2015/01/13 Javascript
js实现的捐赠管理完整实例
2015/01/20 Javascript
jquery比较简洁的软键盘特效实现方法
2015/03/19 Javascript
50 个 jQuery 插件可将你的网站带到另外一个高度
2016/04/26 Javascript
js 中文汉字转Unicode、Unicode转中文汉字、ASCII转换Unicode、Unicode转换ASCII、中文转换
2016/12/06 Javascript
给vue项目添加ESLint的详细步骤
2017/09/29 Javascript
详解nodejs 开发企业微信第三方应用入门教程
2019/03/12 NodeJs
vue cli3.0 引入eslint 结合vscode使用
2019/05/27 Javascript
layUI实现三级导航菜单效果
2019/07/26 Javascript
js实现从右往左匀速显示图片(无缝轮播)
2020/06/29 Javascript
js实现简单抽奖功能
2020/11/24 Javascript
Openlayers实现地图全屏显示
2020/09/28 Javascript
[00:58]2016年国际邀请赛勇士令状宣传片
2016/06/01 DOTA
[55:54]FNATIC vs EG 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/16 DOTA
python实现矩阵乘法的方法
2015/06/28 Python
为什么入门大数据选择Python而不是Java?
2018/03/07 Python
实例讲解python中的协程
2018/10/08 Python
基于wxPython的GUI实现输入对话框(2)
2019/02/27 Python
python抓取搜狗微信公众号文章
2019/04/01 Python
python中def是做什么的
2020/06/10 Python
利用python进行文件操作
2020/12/04 Python
css3打造一款漂亮的卡哇伊按钮
2013/03/20 HTML / CSS
在C语言中"指针和数组等价"到底是什么意思?
2014/03/24 面试题
数据库测试通常都包括哪些方面
2015/11/30 面试题
EJB timer的种类
2014/10/28 面试题
2014基层党员干部学习全国两会心得体会
2014/03/17 职场文书
我心目中的好老师活动方案
2014/08/19 职场文书
支部书记四风对照材料
2014/08/28 职场文书
学校领导班子四风问题整改意见
2014/10/02 职场文书
2015年政治教研组工作总结
2015/07/22 职场文书
Go语言-为什么返回值为接口类型,却返回结构体
2021/04/24 Golang
你知道Java Spring的两种事务吗
2022/03/16 Java/Android