laravel 命令、laravel实战教程

2024-12-07 0 131

Laravel 命令、Laravel实战教程

在现代Web开发中,Laravel框架因其简洁优雅的语法和强大的功能而受到广泛欢迎。介绍如何使用Laravel命令来解决常见的开发问题,并通过一个实战项目来展示Laravel的强大之处。

简述解决方案

在开发过程中,我们经常会遇到需要快速生成控制器、模型、迁移文件等任务。Laravel提供了一套强大的命令行工具Artisan,可以帮助我们高效地完成这些任务。通过实战项目,我们可以更好地理解Laravel的工作原理和实践。

使用Laravel命令生成文件

生成控制器

假设我们需要生成一个名为PostController的控制器,可以使用以下命令:

bash
php artisan make:controller PostController

这将在app/Http/Controllers目录下生成一个名为PostController.php的文件。默认情况下,生成的控制器是空的,但我们可以添加一些常用的方法,如indexcreatestore等。

生成模型和迁移文件

如果需要生成一个模型及其对应的迁移文件,可以使用以下命令:

bash
php artisan make:model Post -m

这将在app/Models目录下生成一个名为Post.php的模型文件,并在database/migrations目录下生成一个迁移文件。迁移文件用于定义数据库表结构。

运行迁移

生成迁移文件后,可以使用以下命令来运行迁移,创建数据库表:

bash
php artisan migrate

生成视图

虽然Laravel没有直接提供生成视图的命令,但我们可以在resources/views目录下手动创建视图文件。例如,创建一个名为posts/index.blade.php的视图文件:

html
<!-- resources/views/posts/index.blade.php -->
@extends('layouts.app')</p>

<p>@section('content')
    <h1>Posts</h1>
    <ul>
        @foreach ($posts as $post)
            <li>{{ $post->title }}</li>
        @endforeach
    </ul>
@endsection

实战项目:博客系统

项目

我们将构建一个简单的博客系统,包括的增删改查功能。项目结构如下:

  • app/Http/Controllers/PostController.php
  • app/Models/Post.php
  • database/migrations/2023_10_01_000000_create_posts_table.php
  • resources/views/posts/index.blade.php
  • resources/views/posts/create.blade.php
  • resources/views/posts/edit.blade.php

创建控制器

生成PostController

bash
php artisan make:controller PostController --resource

定义路由

routes/web.php中定义路由:

php
use AppHttpControllersPostController;</p>

<p>Route::resource('posts', PostController::class);

实现控制器方法

编辑PostController.php,实现增删改查方法:

php
namespace AppHttpControllers;</p>

<p>use AppModelsPost;
use IlluminateHttpRequest;</p>

<p>class PostController extends Controller
{
    public function index()
    {
        $posts = Post::all();
        return view('posts.index', compact('posts'));
    }</p>

<pre><code>public function create()
{
    return view('posts.create');
}

public function store(Request $request)
{
    $validated = $request->validate([
        'title' => 'required|max:255',
        'content' => 'required',
    ]);

    Post::create($validated);

    return redirect()->route('posts.index')->with('success', 'Post created successfully.');
}

public function edit(Post $post)
{
    return view('posts.edit', compact('post'));
}

public function update(Request $request, Post $post)
{
    $validated = $request->validate([
        'title' => 'required|max:255',
        'content' => 'required',
    ]);

    $post->update($validated);

    return redirect()->route('posts.index')->with('success', 'Post updated successfully.');
}

public function destroy(Post $post)
{
    $post->delete();

    return redirect()->route('posts.index')->with('success', 'Post deleted successfully.');
}

}

创建视图

创建create.blade.php

html
<!-- resources/views/posts/create.blade.php -->
@extends('layouts.app')</p>

<p>@section('content')
    <h1>Create Post</h1>
    
        @csrf
        <div>
            <label for="title">Title</label>
            
        </div>
        <div>
            <label for="content">Content</label>
            <textarea name="content" id="content"></textarea>
        </div>
        <button type="submit">Create Post</button>
    
@endsection

创建edit.blade.php

html
<!-- resources/views/posts/edit.blade.php -->
@extends('layouts.app')</p>

<p>@section('content')
    <h1>Edit Post</h1>
    id) }}" method="POST">
        @csrf
        @method('PUT')
        <div>
            <label for="title">Title</label>
            title }}" required>
        </div>
        <div>
            <label for="content">Content</label>
            <textarea name="content" id="content">{{ $post->content }}</textarea>
        </div>
        <button type="submit">Update Post</button>
    
@endsection

运行项目

启动Laravel开发服务器:

bash
php artisan serve

访问http://localhost:8000/posts,即可看到博客系统的界面。

通过以上步骤,我们成功地使用Laravel命令和实战项目展示了Laravel的强大功能和灵活性。希望对你的Laravel开发之旅有所帮助。

Image

1. 本站所有资源来源于用户上传和网络,因此不包含技术服务请大家谅解!如有侵权请邮件联系客服!cheeksyu@vip.qq.com
2. 本站不保证所提供下载的资源的准确性、安全性和完整性,资源仅供下载学习之用!如有链接无法下载、失效或广告,请联系客服处理!
3. 您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容资源!如用于商业或者非法用途,与本站无关,一切后果请用户自负!
4. 如果您也有好的资源或教程,您可以投稿发布,成功分享后有积分奖励和额外收入!
5.严禁将资源用于任何违法犯罪行为,不得违反国家法律,否则责任自负,一切法律责任与本站无关

源码下载