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
桌面中心(二)数据库写入
Oct 09 PHP
oracle资料库函式库
Oct 09 PHP
一个简单的php实现的MySQL数据浏览器
Mar 11 PHP
关于ob_get_contents(),ob_end_clean(),ob_start(),的具体用法详解
Jun 24 PHP
PHP内核探索:变量概述
Jan 30 PHP
浅谈php7的重大新特性
Oct 23 PHP
php 伪造HTTP_REFERER页面URL来源的三种方法
Sep 22 PHP
php自定义截取中文字符串-utf8版
Feb 27 PHP
PHP基于自增数据如何生成不重复的随机数示例
May 19 PHP
php设计模式之组合模式实例详解【星际争霸游戏案例】
Mar 27 PHP
php + ajax 实现的写入数据库操作简单示例
May 16 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
《雄兵连》系列首部大电影《烈阳天道》:可能是因为期望值太高了
2020/08/18 国漫
生成php程序的php代码
2008/04/07 PHP
PHP扩展Swoole实现实时异步任务队列示例
2019/04/13 PHP
关于 文本框默认值 的操作js代码
2012/01/12 Javascript
各种常用的JS函数整理
2013/10/25 Javascript
jQuery标签编辑插件Tagit使用指南
2015/04/21 Javascript
js判断子窗体是否关闭的方法
2015/08/11 Javascript
jquery实现ajax提交表单信息的简单方法(推荐)
2016/08/24 Javascript
Javascript中八种遍历方法的执行速度深度对比
2017/04/25 Javascript
vue登录注册及token验证实现代码
2017/12/14 Javascript
浅谈es6 javascript的map数据结构
2017/12/14 Javascript
AngularJS中ng-options实现下拉列表的数据绑定方法
2018/08/13 Javascript
js中实例与对象的区别讲解
2019/01/21 Javascript
layui多图上传实现删除功能的例子
2019/09/23 Javascript
基于javascript原生判断DOM是否加载完毕
2020/10/14 Javascript
python基础教程之对象和类的实际运用
2014/08/29 Python
Python基类函数的重载与调用实例分析
2015/01/12 Python
Python2.6版本中实现字典推导 PEP 274(Dict Comprehensions)
2015/04/28 Python
基于进程内通讯的python聊天室实现方法
2015/06/28 Python
Python3.2模拟实现webqq登录
2016/02/15 Python
python strip() 函数和 split() 函数的详解及实例
2017/02/03 Python
python调用百度REST API实现语音识别
2018/08/30 Python
使用Python刷淘宝喵币(低阶入门版)
2019/10/30 Python
Python 如何反方向迭代一个序列
2020/07/28 Python
财务部出纳岗位职责
2013/12/22 职场文书
高中语文课后反思
2014/04/27 职场文书
文明工地标语
2014/06/16 职场文书
收款授权委托书
2014/10/02 职场文书
2014年学校法制宣传日活动总结
2014/11/01 职场文书
2014年个人工作总结报告
2014/11/27 职场文书
创业计划之特色精品店
2019/08/12 职场文书
2020年元旦晚会策划书模板
2019/12/30 职场文书
python实战之用emoji表情生成文字
2021/05/08 Python
Element实现动态表格的示例代码
2021/08/02 Javascript
图文详解nginx日志切割的实现
2022/01/18 Servers
MySQL数据库实验之 触发器和存储过程
2022/06/21 MySQL