承接 lin3s/wp-routing 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

lin3s/wp-routing

最新稳定版本:v2.0.1

Composer 安装命令:

composer require lin3s/wp-routing

包简介

Symfony style routing for WordPress

README 文档

README

Symfony style routing for WordPress.

SensioLabsInsight Build Status Scrutinizer Code Quality Total Downloads      Latest Stable Version Latest Unstable Version

Why?

WordPress routing system is a magical awesome but dark system. For non developers this routing just "works" but, when you need to customize it, this process is not very intuitive. In LIN3S, we are proud PHP developers that like Symfony ecosystem so, this library is a simple but powerful approach to Symfony Routing component you can easily add to your WordPress project.

If you want to test it, we already have a functional WordPress project that includes this library ready to use, WordPress Standard Edition :).

Installation

The recommended and the most suitable way to install this library is through Composer. Be sure that the tool is installed in your system and execute the following command:

$ composer require lin3s/wp-routing

Usage

Before you start using this library we highly recommend getting familiar with WordPress template hierarchy.

WP-Routing uses YAML to match routes with your methods. For example you can write the following in your routing.yml:

-
  controller: YourTheme\Controller\DefaultController::indexAction
  type: front

-
  controller: WordpressStandard\Controller\DefaultController::notFoundAction
  type: 404

-
  controller: YourTheme\Controller\EventController::searchAction
  type: search

-
  controller: YourTheme\Controller\YourPostTypeController::singleAction
  type: single
  posttype: your-posttype

-
  controller: YourTheme\Controller\PageController::availabilityAction
  type: page
  template: your-template

As you can see in the example above you can use the following parameters for each route:

  • controller: Defines with method will be called when a match for the given route exists.
  • type: Which type of route will match the current controller. It uses WordPress standard naming conventions and you can check the available ones in Router class.
  • template: Can be used in pages to select a custom template. Internally it uses get_page_template_slug() to get the template the page requires. We use our template-selector plugin to let the user select the template to be used.
  • other parameters: In case you need to target a specific category, post type (archive or single), taxonomy or page you can use extra parameters like slug, id or posttype (see variable names on WordPress's template hierarchy page).

To resolve the routes added above just include the following code in your theme's index.php:

(new \LIN3S\WPRouting\Router())->resolve();

Make sure WPRouting library is autoloaded using composer's autoload script

To Do

  • Add more specs
  • Route registration wih XML
  • Route registration wih annotations

Licensing Options

License

统计信息

  • 总下载量: 6.65k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 2
  • 依赖项目数: 0
  • 推荐数: 1

GitHub 信息

  • Stars: 0
  • Watchers: 2
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2015-07-23

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固