Laravel 簡(jiǎn)單實(shí)現(xiàn)Ajax滾動(dòng)加載示例
開(kāi)發(fā)H5項(xiàng)目的時(shí)候我們總是需要用到下拉滾動(dòng)刷新的方式加載頁(yè)面。這里用 Laravel 實(shí)現(xiàn)一下,直接上代碼:
創(chuàng)建模型
這里我們不妨創(chuàng)建一個(gè) 文章(Post)模型, 并且生成測(cè)試數(shù)據(jù) 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"); } }
測(cè)試數(shù)據(jù) 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 分頁(yè)滾動(dòng)加載</title> <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script> <link 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 分頁(yè)滾動(dòng)加載</h2> <br/> <div class="col-md-12" id="post-data"> @include('data') </div> </div> <div class="ajax-load text-center" style="display:none"> <p>加載更多……</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("沒(méi)有數(shù)據(jù)了……"); return; } $('.ajax-load').hide(); $("#post-data").append(data.html); }) .fail(function(jqXHR, ajaxOptions, thrownError) { alert('服務(wù)未響應(yīng)……'); }); } </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 簡(jiǎn)單實(shí)現(xiàn)Ajax滾動(dòng)加載示例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
織夢(mèng)sitemap地圖實(shí)時(shí)推送給百度的教程
這篇文章主要介紹了織夢(mèng)sitemap地圖實(shí)時(shí)推送給百度的教程,需要的朋友可以參考下2015-08-08destoon網(wǎng)站轉(zhuǎn)移服務(wù)器后搜索漢字出現(xiàn)亂碼的解決方法
這篇文章主要介紹了destoon網(wǎng)站轉(zhuǎn)移服務(wù)器后搜索漢字出現(xiàn)亂碼的解決方法,非常實(shí)用,需要的朋友可以參考下2014-06-06Laravel中unique和exists驗(yàn)證規(guī)則的優(yōu)化詳解
這篇文章主要給大家介紹了關(guān)于Laravel中unique和exists驗(yàn)證規(guī)則的優(yōu)化的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2018-01-01TP5(thinkPHP框架)實(shí)現(xiàn)后臺(tái)清除緩存功能示例
這篇文章主要介紹了TP5(thinkPHP框架)實(shí)現(xiàn)后臺(tái)清除緩存功能,結(jié)合實(shí)例形式分析了thinkPHP5結(jié)合layui插件實(shí)現(xiàn)后臺(tái)緩存清除相關(guān)的文件遍歷、刪除等操作技巧,需要的朋友可以參考下2019-05-05發(fā)款php蜘蛛統(tǒng)計(jì)插件只要有mysql就可用
有時(shí)候我們?yōu)榱丝匆幌轮┲肱佬械那闆r,不得不對(duì)日志進(jìn)行大量的分析,由此想做一款插件可以記錄蜘蛛的情況。在第一次做的時(shí)候,只是記錄下蜘蛛的爬行次數(shù),不大好分析。2010-10-10微信小程序 消息推送php服務(wù)器驗(yàn)證實(shí)例詳解
這篇文章主要介紹了微信小程序 消息推送php服務(wù)器驗(yàn)證實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-03-03Yii2實(shí)現(xiàn)跨mysql數(shù)據(jù)庫(kù)關(guān)聯(lián)查詢排序功能代碼
本篇文章主要介紹了Yii2實(shí)現(xiàn)跨mysql數(shù)據(jù)庫(kù)關(guān)聯(lián)查詢排序功能示例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-02-02php opendir()列出目錄下所有文件的實(shí)例代碼
這篇文章主要介紹了php opendir()列出目錄下所有文件的實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2016-10-10Laravel實(shí)現(xiàn)自定義錯(cuò)誤輸出內(nèi)容的方法
這篇文章主要介紹了Laravel實(shí)現(xiàn)自定義錯(cuò)誤輸出內(nèi)容的方法,結(jié)合實(shí)例形式分析了Laravel自定義錯(cuò)誤輸出信息的相關(guān)操作技巧,需要的朋友可以參考下2016-10-10