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 相关文章推荐
PHP新手上路(八)
Oct 09 PHP
基于PHP选项与信息函数的使用详解
May 10 PHP
PHP 实现代码复用的一个方法 traits新特性
Feb 22 PHP
两种php给图片加水印的实现代码
Apr 18 PHP
PHP输入流php://input实例讲解
Dec 22 PHP
php+jQuery递归调用POST循环请求示例
Oct 14 PHP
[原创]php集成安装包wampserver修改密码后phpmyadmin无法登陆的解决方法
Nov 23 PHP
PHP等比例压缩图片的实例代码
Jul 26 PHP
PHP聊天室简单实现方法详解
Dec 08 PHP
php workerman定时任务的实现代码
Dec 23 PHP
laravel-admin 管理平台获取当前登陆用户信息的例子
Oct 08 PHP
PhpSpreadsheet设置单元格常用操作汇总
Nov 13 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 empty,isset,is_null判断比较(差异与异同)
2010/10/19 PHP
php 获取全局变量的代码
2011/04/21 PHP
php 获取页面中指定内容的实现类
2014/01/23 PHP
PHP传参之传值与传址的区别
2015/04/24 PHP
php array_key_exists() 与 isset() 的区别
2016/10/24 PHP
javascript Onunload与Onbeforeunload使用小结
2009/12/31 Javascript
JavaScript 异步方法队列链实现代码分析
2010/06/05 Javascript
js获取多个tagname的节点数组
2013/09/22 Javascript
javascript对象的使用和属性操作示例详解
2014/03/02 Javascript
浅谈JavaScript函数节流
2014/12/09 Javascript
jquery获取当前日期的方法
2015/01/14 Javascript
js判断文本框剩余可输入字数的方法
2015/02/04 Javascript
jQuery实现按钮的点击 全选/反选 单选框/复选框 文本框 表单验证
2015/06/25 Javascript
Javascript 正则表达式校验数字的简单实例
2016/11/02 Javascript
React Native中导航组件react-navigation跨tab路由处理详解
2017/10/31 Javascript
[47:45]Liquid vs OG 2018国际邀请赛小组赛BO2 第二场 8.16
2018/08/17 DOTA
Python的Bottle框架中返回静态文件和JSON对象的方法
2015/04/30 Python
举例讲解Python面向对象编程中类的继承
2016/06/17 Python
python+numpy+matplotalib实现梯度下降法
2018/08/31 Python
Python列表与元组的异同详解
2019/07/02 Python
python自动化测试无法启动谷歌浏览器问题
2019/10/10 Python
Python如何转换字符串大小写
2020/06/04 Python
Python实现FTP文件定时自动下载的步骤
2020/12/19 Python
Jabra捷波朗美国官网:用于办公、车载和运动的无线蓝牙耳麦
2017/02/01 全球购物
ProForm英国站点:健身房和健身器材网上商店
2019/06/05 全球购物
璀璨的珍珠、密钉和个性化珠宝:Lily & Roo
2021/01/21 全球购物
网络技术专业求职信
2014/05/02 职场文书
教师演讲稿大全
2014/05/16 职场文书
企业职业病防治方案
2014/05/29 职场文书
文明寝室标语
2014/06/13 职场文书
委托书如何写
2014/08/30 职场文书
政风行风评议心得体会
2014/10/21 职场文书
党的群众路线教育实践活动心得体会范文
2014/11/05 职场文书
巾帼文明岗事迹材料
2014/12/24 职场文书
学校青年志愿者活动总结
2015/05/06 职场文书
企业法人代表证明书
2015/06/18 职场文书