簡體   English   中英

編輯/更新數據庫Laravel

[英]Edit / Update database Laravel

我正在努力使用編輯表單來更新數據庫中的數據,但找不到符合我的設置邏輯的任何在線內容。

我有一個添加按鈕,刪除按鈕和一個編輯按鈕。 添加和刪​​除有效,但編輯不會更新數據。

任何幫助將不勝感激,因為我嘗試了多種方法但均未成功。

先感謝您。

視圖:

@extends('layouts.app')
@section('content')
    <div class="container flex-center">
        <div class="row col-md-8 flex-column">
            <h1>Edit a link</h1>
            @foreach ($links as $link)
            <form action="{{ url('link/'.$link->id) }}" method="POST">
              {!! csrf_field() !!}
              @method('PUT')
                @if ($errors->any())
                    <div class="alert alert-danger" role="alert">
                        Please fix the following errors
                    </div>
                @endif

                <h3 class="edit-link-title">{{ $link->title }}</h3>
                {!! csrf_field() !!}
                <div class="form-group{{ $errors->has('title') ? ' has-error' : '' }}">
                    <label for="title">Title</label>
                    <input type="text" class="form-control" id="title" name="title" placeholder="Title" value="{{ $link->title }}">
                    @if($errors->has('title'))
                        <span class="help-block">{{ $errors->first('title') }}</span>
                    @endif
                </div>
                <div class="form-group{{ $errors->has('url') ? ' has-error' : '' }}">
                    <label for="url">Url</label>
                    <input type="text" class="form-control" id="url" name="url" placeholder="URL" value="{{ $link->url }}">
                    @if($errors->has('url'))
                        <span class="help-block">{{ $errors->first('url') }}</span>
                    @endif
                </div>
                <div class="form-group{{ $errors->has('description') ? ' has-error' : '' }}">
                    <label for="description">Description</label>
                    <textarea class="form-control" id="description" name="description" placeholder="description">{{ $link->description }}</textarea>
                    @if($errors->has('description'))
                        <span class="help-block">{{ $errors->first('description') }}</span>
                    @endif
                    @endforeach
                </div>
                <button type="submit" class="btn btn-default submit-btn">Submit</button>
            </form>
        </div>
    </div>
@endsection

網絡/路由控制器:

use Illuminate\Http\Request;

Route::post('/submit', function (Request $request) {
  $data = $request->validate([
      'title' => 'required|max:255',
      'url' => 'required|url|max:255',
      'description' => 'required|max:255',
  ]);

  $link = tap(new App\Link($data))->save();

  return redirect('/');
});

use App\Link;

Route::delete('/link/{link}', function (Link $link) {
  // Link::destroy($link);
  $link->delete();
  return redirect('/');
});

Route::PUT('/link/{link}', function (Link $link) {
  $link->update();
  return redirect('/');
});

作為一種設計模式,通常建議將您的控制器與路線分開。 您的編輯沒有更新的原因是您沒有向模型提供請求中的數據:-

Route::PUT('/link/{link}', function (Request $request, Link $link) {
    $request->validate([
        'title' => 'required|max:255',
        'url' => 'required|url|max:255',
        'description' => 'required|max:255',
    ]);
    $link->update($request->all());
    return redirect('/');
});

在控制器中,您可以將驗證邏輯抽象為驗證助手功能,以避免重復代碼。

祝好運!

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM