本文实例讲述了Laravel5.1 框架路由基础。分享给大家供大家参考,具体如下:
大K简单的说下,路由是用户访问我们程序的一个入口,比方说 你在浏览器输入:www.myblogs.com/create 就会打开一个页面,我们接收到这一个请求后后台需要做一些事儿来反馈给用户一些东西。
首先呢laravel的路由定义在这个路径下:app/Http/routes.php
/** * 这是Laravel提供给我们的主界面路由,输入 localhost:8000(如果你用的artisan控制台)就可以看到主界面啦 */ Route::get('/', function () { return view('welcome'); }); /** * 我们自己定义了get路由 * 浏览器输入 localhost:8000/get 就可以看到啦。 */ Route::get('/get', function (){ return '这是我们自己定义的get路由'; }); /** * 我们自己定义了post路由 */ Route::get('/post', function (){ return '这是我们自己定义的post路由'; });
备注:路由方法不只有 get和post 还有put啊 delete啊等,具体可以根据实际情况使用。
/** * 使用match可以匹配多种方法到一个路径下, localhost:8000/hello 支持GET方法也支持POST方法。 */ Route::match(['get', 'post'], '/hello', function (){ return 'hi~ 我是大K'; }); /** * any 顾名思义 它可以匹配所有的方法。 */ Route::any('/any', function (){ return 'any能匹配所有的方法'; });
咱在写项目的时候啊 经常需要从路由中捕获参数以便之后的处理,那如何声明呢,继续看:
/** * 参数的写法简单 加个花括号就行,然后在后面的闭包中捕获它就行。 */ Route::get('/user/{id}', function ($id){ return '咱成功的拿到了一个用户ID:' . $id; });
/** * 可选参数只要在参数名后面跟个问号就好,然后在闭包中给它个默认值就好。 */ Route::get('/user/{id}/name/{name?}/descriptions/{description?}', function ($user_id, $user_name = 'K', $user_description = null){ return '咱捕获了一堆参数 其中必选参数:'.$user_id.'可选的两个参数 名字:'.$user_name.'简介:'.$user_description; });
大K呢在上面两个例子中写的不太严谨,就那第一个例子说吧,一般id都是正整数的,可是第一个例子里咱输入一串鸟文它也能识别到,咱应该加串儿正则让它变得挑食点儿:
/** * 参数的写法简单 加个花括号就行,然后在后面的闭包中捕获它就行。 * 后面跟了个where方法,里面限制了id参数必须是数字。 */ Route::get('/user/{id}', function ($id){ return '咱成功的拿到了一个用户ID(现在我只能接受数字):' . $id; })->where('id','[0-9]+'); /** * 如果对多个参数进行约束,那咱就得在where方法中给数组啦。 */ Route::get('/user/{id}/name/{name?}', function ($id, $name = 'k'){ return '咱成功的拿到了一个用户ID(现在我只能接受数字):' . $id . '名字:' . $name; })->where(['id' => '[0-9]+','name' => '[a-zA-Z]+']);
在实际开发中啊,一般参数为ID的一般都是整数,如果咱每个路由后面都跟个where是不是倍儿烦躁?甭担心,有一步到位的方法:在app/Providers/RouteServiceProvider.php 文件中boot方法,添加一段代码就行:
public function boot(Router $router) { $router->pattern('id', '[0-9]+'); parent::boot($router); }
然后修改一下刚刚的例子:
Route::get('/user/{id}', function ($id){ return '咱成功的拿到了一个用户ID(现在我只能接受数字):' . $id; }); Route::get('/user/{id}/name/{name?}', function ($id, $name = 'k'){ return '咱成功的拿到了一个用户ID(现在我只能接受数字):' . $id . '名字:' . $name; })->where('name','[A-Za-z]+');
为啥要给路由起名字?咱想一下这么一个场景啊 : 进到某一个路由后 我们需要在数据库中更新一条信息,当信息更新完了后要跳转到另外一条路由,这条路由的路径是:localhost:8000/xxxx/sdfsa/xasfes/xaefsggd/xaeqwes/xadfase(当然啦 我是乱敲的) 难道我们要手动打xxxx/sdfsa/xa...么?或者你可以说 copy一下,但是我们给这条路由起一个名字,直接使用名字来跳转 岂不美哉?
/** * 现在比如说 用户在更新他的名字 拿到名字后在数据库中更新 更新完了跳转到另一个路由 */ Route::get('/user/{id}/name/{name}', function ($id, $name){ // 更新数据库操作 // ... // 跳转 return redirect()->route('showUser',['name' => $name]); })->where('name','[A-Za-z]+'); /** * 另一条路由 (路径瞎写的啊) * 在路径后面加一个数组 as=>router_name 就是这么个流程。 */ Route::get('/admin/private/user/show/{name}', ['as' => 'showUser', function($name){ return '哇 你的名字已经更新完啦:'.$name; }]);
更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。
本文向大家介绍Laravel5.1框架路由分组用法实例分析,包括了Laravel5.1框架路由分组用法实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Laravel5.1框架路由分组用法。分享给大家供大家参考,具体如下: 路由分组有啥好处? 有时候啊 一大堆路由它们都有共同的地方,比如都使用一个中间件(过两天写)或是前缀都一样,避免代码重复 我们可以将他们分到一组中。 1 路由分组
主要内容:基础类的功能如果您参考Apple文档,应该会看到框架的详细信息,如下所示。 框架定义了Objective-C类的基础层。 除了提供一组有用的原始对象类之外,它还引入了几个定义Objective-C语言未涵盖的功能的范例。 框架的设计考虑了这些目标 - 提供一小组基本实用程序类。 通过为解除分配等事项引入一致的约定,使软件开发更容易。 支持Unicode字符串,对象持久性和对象分发。 提供一定程度的操作系统独立
Routing refers to determining how an application responds to a client request to a particular endpoint, which is a URI (or path) and a specific HTTP request method (GET, POST, and so on). Each route c
本文向大家介绍Laravel框架路由与MVC实例详解,包括了Laravel框架路由与MVC实例详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Laravel框架路由与MVC。分享给大家供大家参考,具体如下: 1、路由 路由的作用就是将用户的不同url请求转发给相应的程序进行处理,laravel的路由定义在routes文件夹中,默认提供了四个路由文件,其中web.php文件定义基本页面请
本文向大家介绍asp.net-mvc 路由基础,包括了asp.net-mvc 路由基础的使用技巧和注意事项,需要的朋友参考一下 示例 当您yourSite/Home/Index通过浏览器请求url时,路由模块会将请求定向到class的Indexaction方法HomeController。如何知道将请求发送到此特定类的特定方法?出现了RouteTable。 每个应用程序都有一个路由表,在其中存储路
路由配置是一组指令,用来告诉 router 如何匹配 URL以及匹配后如何执行代码。我们来通过一个简单的例子解释一下如何编写路由配置。 import React from 'react' import { render } from 'react-dom' import { Router, Route, Link } from 'react-router' const App = React.cr