zoukankan      html  css  js  c++  java
  • 关于 laravel 分页 seo浅谈

    laravel 的分页是非常简单易用的,但是有一点不是非常理想,

     

    默认的分页生成的链接是

    users?page=1
    

      

    这种形式对seo不是非常友好(理论上)

    那么我们可能就需要像

    users/page/1 
    

      

    这种形式的分页链接

    那么怎么做到呢?

    我现在有两种方式实现的方式

    第一种是我之前项目中采用的,直接上正则

    直接在blade中进行正则替换

    {!! preg_replace("~(/?)?page=~", '/page/', $users->render()) !!} 
    

      

    该正则应该有优化的空间,还望不吝赐教。

    当然对应的路由也要相应的配置,很简单,就不展开了。

    这种方法效果是实现了,但是真的很没有laravel的风格啊

    laravel的风格是什么? composer , package啊

    所以来介绍一下第二种方法

    laravel-paginateroute
    

      

    使用方法非常简单,以下摘自readme

    第一步

    // 要注意对应版本,可到https://packagist.org 方便查看
    composer require spatie/laravel-paginateroute
    

      

    第二步

    注册,

    // config/app.php
    'providers' => [
     ...
     'SpatiePaginateRoutePaginateRouteServiceProvider',
    ];
    'aliases' => [
     ...
     'PaginateRoute' => 'SpatiePaginateRoutePaginateRouteFacade',
    ];
    

      

    第三步

    // app/Providers/RouteServiceProvider.php
    use PaginateRoute;
    // ...
    public function boot(Router $router)
    {
     PaginateRoute::registerMacros();
     parent::boot($router);
    }
    

      

    使用

    在路由中

    // app/Http/routes.php
    // Generates /users & /users/page/{page}
    Route::paginate('users', 'UsersController@index');
    

      

    这样会生成两条路由

    /users
    /users/page/{page} 
    

      

    然后在controller中正常按照laravel的分页写就可以

    在页面中这样使用,这个是simplePaginate的对应写法

    @if(PaginateRoute::hasPreviousPage())
     <a href="{{ PaginateRoute::previousPageUrl() }}">Previous</a>
    @endif
    @if(PaginateRoute::hasNextPage($users))
     <a href="{{ PaginateRoute::nextPageUrl($users) }}">Next</a>
    @endif 
    

      

  • 相关阅读:
    面试常考点:http和https的区别与联系
    常见的反爬虫和应对方法
    2019/1/1 Python今日收获
    2018/12/26,12/27 Python今日收获
    2018/6/7-6/8 Python今日收获
    2018/6/6 Python今日收获
    CSS(3)——visited伪类
    CSS中margin和padding的区别
    CSS(2)——CSS的文字,边框,背景与列表
    CSS(1)——CSS的引入方式与选择器
  • 原文地址:https://www.cnblogs.com/a609251438/p/12698568.html
Copyright © 2011-2022 走看看