首页 > 作文

Laravel 5 框架入门(二)构建 Pages 的管理功能

更新时间:2023-04-06 19:16:13 阅读: 评论:0

我们将改变学习路线,不再像 laravel 4 教程那样先构建登录系统。在本篇教程中,我们将一起构建 pages 的管理功能,尝试 laravel 的路由和 php 的命名空间。

1. 路由
laravel 中的路由,跟其他 php 框架一样,作用是把各种请求分流到各个控制器。

在 `learnlaravel5/app/http/routes.php` 的美的电饭煲维修点末尾添加以下代码:

复制代码 代码如下:

route::group([‘prefix’ => ‘admin’, ‘namespace’ => ‘admin’], function()

{

route::get(‘/’, ‘adminhomecontroller@index’);

});

这表示创建了一个路由组。

1. `’prefix’ => ‘admin’` 表示这个路由组的 url 前缀是 /admin,也就是说中间那一行代码 `route::get(‘/’` 对应的链接不是 而是 ,如果这段代码是 `route::get(‘fuck’` 的话,那么 url 就应该是 。

2. `’namespace’ => ‘admin’` 表示下面的 `adminhomecontroller@index` 不是在 `\app\http\controllers\adminhomecontroller@index` 而是在 `\app\http\controllers\admin\adminhomecontroller@index`,加上了一个命名空间的前缀。

如果你用过 laravel 4,会发现 laravel 5 的命名空间规划比较怪异,这其实是一个非常大的进步。laravel 4 其实已经全面引入了命名空间这个强大的特性,但是为了“降低学习成本”,把 路由、控制器、模型 的默认命名空间全部设置成了顶级命名空间,这个举动反而让很多人比较轻易地“上手”了 laravel,但是在用了一段时间以后,还需要翻越一堵高墙,那就是命名空间,而且有了前面的“容易上手”的印象作为铺垫,后期的学习会更加困难。laravel 5 把命名空间全部隔开,控制器在 `\app\http\controllers`,模型在 `\app`,让我们在刚上手的时候就体验命名空间分离的感觉,总体上其实是会降低学习成本的。

2. 控制器

我们可以使用 artisan 非常方便地构建控制器:

复制代码 代码如下:

php artisan make:controller admin/adminhomecontroller

得到 `learnlaravel5/app/http/controllers/admin/adminhomecontroller.php` 文件。

在 `class adminhomecontroller extends controller {` 上面增加一行:

复制代码 代码如下:

u app\page;

修改 index() 的代码如下:

复制代码 代码如下:

public function index()

{

return view(‘adminhome’)->withpages(page::all());

}

控制器中文文档:

控制器中涉及到了许多的命名空间知识,可以参考 php 命名空间 解惑。

3. 视图

新建 `learnlaravel5/resources/views/adminhome.blade.php`:

@extends('app')@ction('content')<div class="container"> <div class="row">  <div class="col-md-10 col-md-offt-1">   <div class="panel panel-default">    <div class="panel-heading">后台首页</div>    <div class="panel-body">    <a href="{{ url('admin/pages/create') }}" class="btn btn-lg btn-primary">新增</a>     @foreach ($pages as $page)      <hr>      <div class="page">       <h4>{{ $page->title }}</h4>       <div class="content">        <p>         {{ $page->body }}        </p>       </div>      </div>      <a href="{{ url('admin/pages/'.$page->id.'/edit') }}" class="btn btn-success">编辑</a>      <form action="{{ url('admin/pages/'.$page->id) }}" method="post" style="display: inline;">       <input name="_method" type="hidden" value="delete">       <input type="hidden" name="_token" value="{{ csrf_token() }}">       <button type="submit" class="btn btn-danger">删除</button>      </form>     @endforeach    </div>   </div>  </div> </div></div>@endction

视图的基本用法在此不再赘述,请阅读中文文档:

访问 得到如下页面:

至此,包含 路由 》 控制器 》 模型 》 视图 的整个流程都已经完成。

4. 完成 pages 管理功能

接下来,我将记录下我实现 pages 管理功能的过程,不再做过多的阐述。大家有问题可以直接在本文下面留言,我会及时回复。

4.1 修改路由 learnlaravel5/app/http/routes.php

复制代码 代码如下:

route::group([‘prefix’ => ‘admin’, ‘namespace’ => ‘admin’], function()

{

route::get(‘/’, ̵学校补课6;adminhomecontroller@index’);

route::resource(‘pages’, ‘pagescontroller’);

});

此处增加了一条“资源控制器”,中文文档地址:

4.2 创建 learnlaravel5/app/http/controllers/admin/pagescontroller.php

运行:

复制代码 代码如下:

php artisan make:controller彗星dns优化器 admin/pagescontroller

4.3 修改 learnlaravel5/app/http/controllers/admin/pagescontroller.php 为:

<?php namespace app\http\controllers\admin;u app\http\requests;u app\http\controllers\controller;u illuminate\http\request;u app\page;u redirect, input, auth;class pagescontroller extends controller { /** * show the form for creating a new resource. * * @return respon */ public function create() { return view('admin.pages.create'); } /** * store a newly created resource in storage. * * @return respon */ public function store(request $request) { $this->validate($request, [  'title' => 'required|unique:pages|max:255',  'body' => 'required', ]); $page = new page; $page->title = input::get('title'); $page->body = input::get('body'); $page->ur_id = 1;//auth::ur()->id; if ($page->save()) {  return redirect::to('admin'); } el {  return redirect::back()->withinput()->witherrors('保存失败!'); } } /** * show the form for editing the specified resource. * * @param int $id * @return respon */ public function edit($id) { return view('admin.pages.edit')->withpage(page::find($id)); } /** * update the specified resource in storage. * * @param int $id * @return respon */ public function update(request $request,$id) { $this->validate($request, [  'title' => 'required|unique:pages,title,'.$id.'|max:255',  'body' => 'required', ]); $page = page::find($id); $page->title = input::get('title'); $page->body = input::get('body'); $page->ur_id = 1;//auth::ur()->id; if ($page->save()) {  return redirect::to('admin'); } el {  return redirect::back()->withinput()->witherrors('保存失败!'); } } /** * remove the specified resource from storage. * * @param int $id * @return respon */ public function destroy($id) { $page = page::find($id); $page->delete(); return redirect::to('admin'); }}

4.4 创建视图文件

首先在 learnlaravel5/resources/views 下创建 admin/pages 两级文件夹。

然后创建 learnlaravel5/resources/views/admin/pages/create.blade.php:

@extends('app')@ction('content')<div class="container"> <div class="row">  <div class="col-md-10 col-md-offt-1">   <div class="panel panel-default">    <div class="panel-heading">新增 page</div>    <div class="panel-body">     @if (count($errors) > 0)      <div class="alert alert-danger">       <strong>whoops!</strong> there were some problems with your input.<br><br>       <ul>        @foreach ($errors->all() as $error)         <li>{{ $error }}</li>        @endforeach       </ul>      </div>     @endif     <form action="{{ url('admin/pages') }}" method="post">      <input type="hidden" name="_token" value="{{ csrf_token() }}">      <input type="text" name="title" class="form-control" required="required">      <br>      <textarea name="body" rows="10" class="form-control" required="required"></textarea>      <br>      <button class="btn btn-lg btn-info">新增 page</button>     </form>    </div>   </div>  </div> </div></div>@endction

之后创建 learnlaravel5/resources/views/admin/pages/edit.blade.php:

@extends('app')@ction('content')<div class="container"> <div class="row">  <div class="col-md-10 col-md-offt-1">   <div class="panel panel-default">    <div class="panel-heading">编辑 page</div>    <div class="panel-body">     @if (count($errors) > 0)      <div class="alert alert-danger">       <strong>whoops!</strong> there were some problems with your input.<br><br>       <ul>        @foreach ($errors->all() as $error)         <li>{{ $error }}</li>        @endforeach       </ul>      </div>     @endif     <form action="{{ url('admin/pages/'.$page->id) }}" method="post">      <input name="_method" type="hidden" value="put">      <input type="hidden" name="_token" value="{{ csrf_token() }}">      <input type="text" name="title" class="form-control" required="required" value="{{ $page->title }}">      <br>      <高中万能作文素材;textarea name="body" rows="10" class="form-control" required="required">{{ $page->body }}</textarea>      <br>      <button class="btn btn-lg btn-info">编辑 page</button>     </form>    </div>   </div>  </div> </div></div>@endction

4.5 查看结果

后台首页 :

新增 page :

编辑 page :

页面上的新增、编辑、删除的功能均已经完成,并且加入了表单验证,pages 管理功能完成!

以上所述就是本文的全部内容了,希望对大家熟悉larav文化人类学el5框架能够有所帮助。

本文发布于:2023-04-06 19:16:12,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/d173a1764af3797ed35762c4028a3f28.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:Laravel 5 框架入门(二)构建 Pages 的管理功能.doc

本文 PDF 下载地址:Laravel 5 框架入门(二)构建 Pages 的管理功能.pdf

标签:代码   路由   控制器   空间
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图