Heim Backend-Entwicklung PHP-Tutorial Laravel 5 Grundlagen (9) – Formular

Laravel 5 Grundlagen (9) – Formular

Aug 08, 2016 am 09:26 AM
create form

Zuerst ändern wir die Weiterleitung, um einen Artikel zur Veröffentlichung hinzuzufügen.

<code>Route::get('articles/create', 'ArticlesController@create');</code>
Nach dem Login kopieren

Dann modifizieren Sie den Controller

<code>    public function create() {
        return view('articles.create');
    }</code>
Nach dem Login kopieren

Wir geben eine Ansicht zurück und erstellen eine neue Ansicht. Natürlich könnten wir das Formular direkt mit HTML erstellen, aber wir haben einen funktionaleren Weg. Wir verwenden eine Open-Source-Bibliothek, illuminatehtml, die von Jeffrey Way entwickelt wurde. Abhängige Bibliotheken installieren:

<code>composer require illuminate/html</code>
Nach dem Login kopieren

Die Bibliothek von Laravel muss in Laravel registriert werden, bevor sie verwendet werden kann. In config/app.php können wir das von Laravel bereitgestellte Feld provider sehen, in dem die Bibliotheksfunktionen von Laravel beschrieben werden. Fügen Sie unser neues Laravel Framewirk Service Providers...HtmlProvider am Ende von

hinzu
<code>'Illuminate\Html\HtmlServiceProvider',</code>
Nach dem Login kopieren

Wir möchten zur Einleitung keinen langen Namen wie IlluminateHtmlFromFacade verwenden, sondern etwas Kurzes. Suchen Sie den Abschnitt „Aliases“ im aktuellen app.php und fügen Sie den Alias ​​am Ende hinzu.

<code>'Form'      => 'Illuminate\Html\FormFacade',
'Html'      => 'Illuminate\Html\HtmlFacade',</code>
Nach dem Login kopieren

OK, jetzt erstellen wir die Ansicht, views/articles/create.blade.php

<code>@extends('layout')

@section('content')
    <h1>Write a New Article</h1>

    <hr/>

    {{--使用我们添加的 illuminate\html 开源库--}}
    {!! Form::open() !!}

    {!! Form::close() !!}

@stop</code>
Nach dem Login kopieren

Besuchen Sie /articles/create und sehen Sie sich den Fehler an. Lassen Sie uns testen, was schief gelaufen ist. Nehmen Sie die folgenden Änderungen im Controller vor:

<code>    public function show($id) {
        dd('show');
        
        $article = Article::findOrFail($id);

        return view('articles.show', compact('article'));
    }</code>
Nach dem Login kopieren

Ja, Sie haben es richtig gelesen, fügen Sie einfach die Methode show zur Methode dd() hinzu. Diese Methode gibt einfach eine Nachricht aus und stirbt dann. Besuchen wir noch einmal /articles/create. Was sehen Sie? Sie sehen die Ausgabe show.

Warum haben wir auf create zugegriffen und die Route hat uns show gegeben? Schauen wir uns die Route an und sehen, was passiert ist.

<code>Route::get('articles', 'ArticlesController@index');
Route::get('articles/{id}', 'ArticlesController@show');
Route::get('articles/create', 'ArticlesController@create');</code>
Nach dem Login kopieren

Das Obige ist unsere Route. Beachten Sie, dass articles/{id} bedeutet, dass es sich um einen Platzhalter handelt. Alles nach articles/ wird übereinstimmen, wussten Sie das? Auch unser /articles/create wurde von ihm gematcht. OMG!

Die Lösung besteht darin, die Reihenfolge anzupassen:

<code>Route::get('articles', 'ArticlesController@index');
Route::get('articles/create', 'ArticlesController@create');
Route::get('articles/{id}', 'ArticlesController@show');</code>
Nach dem Login kopieren

Das heißt, Sie sollten diesem Problem bei zukünftigen Routing-Einstellungen immer Aufmerksamkeit schenken, egal ob speziell oder gewöhnlich. Jetzt sind wir zu Besuch articles/create und alles ist in Ordnung.

Überprüfen Sie den Quellcode im Browser. Sie werden feststellen, dass nicht nur method und action generiert werden, sondern auch ein verstecktes _token-Feld generiert wird, während der Server das Formular überprüft, um Fälschungsangriffe durch Hacker zu vermeiden.

Ändern wir unsere Ansicht und fügen Felder hinzu:

<code>@extends('layout')

@section('content')
    <h1>Write a New Article</h1>

    <hr/>

    {{--使用我们添加的 illuminate\html 开源库--}}
    {!! Form::open() !!}
        <div class="form-group">
            {!! Form::label('title', 'Title:') !!}
            {!! Form::text('title', null, ['class' => 'form-control']) !!}
        </div>

        <div class="form-group">
            {!! Form::label('body', 'Body:') !!}
            {!! Form::textarea('body', null, ['class' => 'form-control']) !!}
        </div>

        <div class="form-group">
            {!! Form::submit('Add Article', ['class' => 'btn btn-primary form-control']) !!}
        </div>

    {!! Form::close() !!}

@stop</code>
Nach dem Login kopieren

Wenn das Formular gesendet wird, wird es tatsächlich mit der post-Methode an articles/create gesendet. Wir hoffen jedoch, dass wir post zu /articles wechseln können Methode der Ansicht, legen Sie den Übermittlungspfad fest.

<code>{!! Form::open(['url' => 'articles']) !!}</code>
Nach dem Login kopieren

Dann behandeln wir das Formularübermittlungsereignis in der Route.

<code>Route::post('/articles', 'ArticlesController@store');</code>
Nach dem Login kopieren

Übernehmen wir den Controller

<code>
//注意:将下面的 use 语句删除,我们使用 facade 接口中的 Request
//use App\Http\Requests\Request;

//引入下面的命名空间中的 Request
use Illuminate\Support\Facades\Request;

    public function store() {
        //使用 Illuminate\Html\Request 来返回全部的表单输入字段
        $input = Request::all();

        //我们直接返回$input,来看一下
        return $input;
    }</code>
Nach dem Login kopieren

Wir können das JSON-Ergebnis des Eingabeformulars direkt sehen. Wenn Sie nur den Wert des Felds title benötigen, können Sie Request::get('titel') verwenden.

Wie füge ich es zur Datenbank hinzu? Mit Hilfe des Modells können wir die folgende Methode direkt übernehmen:

<code>Article::create($input);</code>
Nach dem Login kopieren

So einfach ist das, so gewollt

Wenn wir die Massenzuweisung nicht vergessen haben, haben wir das Array $fillable in unserem Modell definiert, um die Felder zu definieren, die direkt in create ausgefüllt werden können.

Ändern Sie den Controller, fügen Sie ihn dem Modell hinzu und speichern Sie ihn in der Datenbank.

<code>    public function store() {
        $input = Request::all();
        Article::create($input);

        return redirect('articles');
    }</code>
Nach dem Login kopieren

Versuchen Sie, einen Datensatz hinzuzufügen, es ist großartig. Aber vergiss es nicht. Wir haben auch ein Feld namens published_at , damit beschäftigen wir uns.

<code>    public function store() {
        $input = Request::all();
        $input['published_at'] = Carbon::now();

        Article::create($input);
        
        return redirect('articles');
    }</code>
Nach dem Login kopieren

Fügen Sie einen neuen Datensatz hinzu und testen Sie ihn.

Es gibt ein weiteres Problem. Das neu hinzugefügte Problem sollte vorne angezeigt werden.

<code>	public function index() {
        //倒序获取文章
        //可以这样
        //$articles = Article::orderBy('published_at', 'desc')->get();
        //简单方式,当然还有 oldest()
        $articles = Article::latest('published_at')->get();

        return view('articles.index', compact('articles'));
    }</code>
Nach dem Login kopieren

Das Obige stellt die Grundlagen von Laravel 5 (9) vor, einschließlich verschiedener Aspekte. Ich hoffe, es wird für Freunde hilfreich sein, die sich für PHP-Tutorials interessieren.

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Binaryx wird wieder umbenannt, und die vier, die es der Gemeinschaft gibt, steigt im Begriff zu steigen? Binaryx wird wieder umbenannt, und die vier, die es der Gemeinschaft gibt, steigt im Begriff zu steigen? Mar 04, 2025 pm 12:00 PM

Binaryx 'Token -Name Änderung: Von BNX auf vier und dann zu Form hat die tiefe Bedeutung hinter strategischen Anpassungen Binaryx kürzlich das Token -Symbol von vier bis $ $ Form geändert, das die Branche weit verbreitet hat. Dies ist nicht das erste Mal, dass Binaryx seinen Namen geändert hat, und sein Token -Symbol hat einen Übergang von BNX auf vier erlebt. In diesem Artikel werden die strategischen Absichten dieser Reihe von Namensänderungen eingehend untersucht. 1. Token Name Change-Prozess und strategische Überlegungen Binaryx starteten zunächst das $ BNX-Token auf der Basis der BNB-Kette im Jahr 2021, um das Gaming-Ökosystem von Play-to-Earn (P2E) zu unterstützen. Anfang 2024, um das Wirtschaftsmodell zu optimieren

Kann es in HTML5 mehrere Formulare geben? Kann es in HTML5 mehrere Formulare geben? Aug 01, 2022 pm 05:28 PM

In HTML5 kann es mehrere Formulare geben. Die Regeln erlauben die Verwendung mehrerer Formular-Tags auf derselben HTML-Seite. Um jedoch zu verhindern, dass das Backend sie beim Senden nicht erkennt, müssen Sie dem Formular unterschiedliche IDs oder Klassen hinzufügen. Die Syntax lautet „<from action= "url" id=" id value 1">Formularelement</from><from action="url" id="id value 2">Formularelement</from>.....".

Kann die create-Anweisung verwendet werden, um eine Tabellenstruktur zu erstellen und neue Datensätze anzuhängen? Kann die create-Anweisung verwendet werden, um eine Tabellenstruktur zu erstellen und neue Datensätze anzuhängen? Jul 25, 2022 am 11:25 AM

kann nicht. Die Funktion der CREATE-Anweisung besteht darin, eine Tabellenstruktur zu erstellen, sie kann jedoch keine neuen Datensätze anhängen. Sie können die INSERT-Anweisung verwenden, um neue Datensätze anzuhängen. Die CREATE-Anweisung kann verwendet werden, um eine neue Tabelle in der Datenbank zu erstellen und die Attribute und Einschränkungen der Datenspalten anzugeben. Die neu erstellte Tabelle ist jedoch eine leere Tabelle und erfordert die Verwendung der INSERT-Anweisung zum Anhängen neuer Datensätze. Mit der INSERT-Anweisung werden eine oder mehrere Zeilen mit Tupeldaten in eine vorhandene Tabelle in der Datenbank eingefügt.

Was ist das Tag, das das Formular in HTML5 definiert? Was ist das Tag, das das Formular in HTML5 definiert? Jul 26, 2022 pm 04:26 PM

Der Tag, der ein Formular in HTML5 definiert, ist „<form>“. Mit dem Formular-Tag wird ein HTML-Formular (Formularfeld) für Benutzereingaben erstellt, um Benutzerinformationen zu sammeln und zu übertragen. Der gesamte Inhalt des Formulars wird mit der Syntax „<form action="Submit Address" method=" übermittelt. Submit-Methode „name="form name">form control</form>". Ein Formular kann ein oder mehrere Formularelemente enthalten, z. B. „input“, „select“ und „textarea“.

Organisieren Sie formularbezogene Elemente umfassend! Organisieren Sie formularbezogene Elemente umfassend! Aug 05, 2022 am 11:45 AM

Dieser Artikel gibt Ihnen eine detaillierte Zusammenfassung der Wissenspunkte zu Formularelementen in HTML. Ich hoffe, er wird Ihnen hilfreich sein!

Was soll ich tun, wenn beim Erstellen der React-App eine Fehlermeldung angezeigt wird? Was soll ich tun, wenn beim Erstellen der React-App eine Fehlermeldung angezeigt wird? Dec 27, 2022 am 11:29 AM

Lösung zum Erstellen eines React-App-Fehlers: 1. Wechseln Sie die Taobao-Spiegelquelle über „npm config set Registry https://registry.npm.taobao.org“ 2. Durch Ausführen von „E:\workspace\demo\p4>npx create-“ Führen Sie den Befehl „react-app todolist“ aus, um es neu zu installieren.

Was soll ich tun, wenn das Formular nicht an PHP übermittelt werden kann? Was soll ich tun, wenn das Formular nicht an PHP übermittelt werden kann? Dec 01, 2022 am 09:08 AM

Lösung für das Formular kann nicht an PHP übermittelt werden: 1. Öffnen Sie die entsprechende Codedatei. 2. Ändern Sie die Anweisung „onload="javascript:document.form1.submit();". 3. Ändern Sie den Namen des Übermittlungsformulars.

php记录搜索引擎蜘蛛爬行记录代码 php记录搜索引擎蜘蛛爬行记录代码 Jun 13, 2016 am 10:08 AM

php记录搜索引擎蜘蛛爬行记录代码。php教程记录搜索引擎蜘蛛爬行记录代码 center form action=setup.php method=post table align=center tr td服务器:/tdtdinput value=localhost name=server //td /tr tr td用

See all articles