利用laravel搭建一个迷你博客实战教程
本文主要给大家介绍的是关于利用laravel搭建一个迷你博客的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍: 一、设计与思路在开始写第一行代码之前,一定要尽量从头到尾将我们要做的产品设计好,避免写完又改,多写不必要的代码。
二、创建路由完成这个博客大概需要以下几条路由:| 路由 | 功能 | | -------- | ---------------- | | 文章列表页面路由 | 返回文章列表页面 | | 新增文章页面路由 | 返回新增文章页面 | | 文章保存功能路由 | 将文章保存到数据库 | | 查看文章页面路由 | 返回文章详情页面 | | 编辑文章页面路由 | 返回编辑文章页面 | | 编辑文章功能路由 | 将文章取出更新后重新保存到数据库 | | 删除文章功能路由 | 将文章从数据库删除 | 可以看到几乎全部是对文章的数据操作路由,针对这种情况,Laravel 提供了非常方便的办法:RESTful 资源控制器和路由。 打开routes.php加入如下代码:只需要上面这样一行代码,就相当于创建了如下7条路由,且都是命名路由,我们可以使用类似route('articles.show') 这样的用法。 name('articles.index');
Route::get('/articles/{id}','ArticlesController@show')->name('articles.show');
Route::get('/articles/create','ArticlesController@create')->name('articles.create');
Route::post('/articles','ArticlesController@store')->name('articles.store');
Route::get('/articles/{id}/edit','ArticlesController@edit')->name('articles.edit');
Route::patch('/articles/{id}','ArticlesController@update')->name('articles.update');
Route::delete('/articles/{id}','ArticlesController@destroy')->name('articles.destroy');
三、创建控制器利用 artisan 创建一个文章控制器: 四、创建基础视图resources/views/layouts/art.blade.php 见模板index.html 五、新建文章表单<form class="form-horizontal" method="post" action="{{route('blog.store')}}">
{{ csrf_field() }} <div class="form-group"> <label for="inputEmail3" class="col-sm-2 control-label">标题 <div class="col-sm-8"> <input type="title" class="form-control" id="title" name="title"> <div class="form-group"> <div class="form-group"> 六、文章存储此时如果你填写新建文章表单点击提交也会跳到一个空白页面,同样的道理,因为我们后续的控制器代码还没写。 要实现文章存储,首先要配置数据库,创建数据表,创建模型,然后再完成存储逻辑代码。 1、配置数据库修改.env文件 2、创建数据表利用 artisan 命令生成迁移: 修改迁移文件 increments('id');
$table->string('title');
$table->longText('content');
$table->timestamps();
});
}
public function down()
{
Schema::dropIfExists('articles');
}
我们创建了一张 articles 表,包含递增的 id 字段,字符串title字段,长文本content字段,和时间戳。 执行数据库迁移: 登录mysql,查看数据表。 3、创建模型利用 artisan 命令创建模型: 打开模型文件,输入以下代码: app/Article.php use IlluminateDatabaseEloquentModel;
class Article extends Model 4、存储逻辑代码打开 ArticlesController.php 控制器,找到 store() 方法。 app/Http/Controllers/ArticlesController.php validate($request,[
'title'=>'required|max:50','content'=>'required|max:500',]);
// 1 orm方式写入
$article = Article::create([
'title'=>$request->title,'content'=>$request->content,]);
//2 或者
/* $article = new Article();
$article->title =$request->title;
$article->content = $request->content;
$article->save();*/
//3 db方式写入 验证错误显示 0)
@foreach($errors->all() as $error)
@endif
七、文章列表展示完成了添加文章功能后,就可以实现我们的文章列表展示页了。 打开 ArticlesController.php 找到 app/Http/Controllers/ArticlesController.php public function index()
{ $articles = Article::orderBy('created_at','asc')->get(); return view('articles.index',['articles'=>$articles]); 视图index.blade.php 添加文章
@endforeach
@foreach($articles as $article) <form action="{{ route('blog.destroy',$article->id) }}" method="post" style="display: inline-block;"> {!! $articles->render() !!} 八、编辑文章表单编辑文章表单其实和之前创建的新建文章表单很类似,只是需要额外将现有的数据读取出来填在表单上。 首先我们在文章列表页的每个文章上添加一个编辑按钮: 视图: <form class="form-horizontal" method="post" action="{{route('blog.update',$article->id)}}">
{{ csrf_field() }} {{ method_field('PATCH') }} <div class="form-group"> <label for="inputEmail3" class="col-sm-2 control-label">标题 <div class="col-sm-10"> <input type="title" class="form-control" id="title" name="title" value="{{ $article->title }}"> <div class="form-group"> <div class="form-group"> 注意这段代码中的 控制器 $article]);
}
//执行修改
public function update(Request $request,$id)
{
$this->validate($request,[
'title' => 'required|max:50',]);
$article = Article::findOrFail($id); return redirect()->route('blog.index'); 九、删除文章删除按钮 控制器: delete();
return back();
}
十、结语本次实验通过一个很简单的迷你博客对 Laravel RESTful 资源控制器和路由,视图,orm进行了强化练习。 好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对编程之家的支持。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |