Laravel 5 Grundlagen (9) – Formular
Zuerst ändern wir die Weiterleitung, um einen Artikel zur Veröffentlichung hinzuzufügen.
<code>Route::get('articles/create', 'ArticlesController@create');</code>
Dann modifizieren Sie den Controller
<code> public function create() { return view('articles.create'); }</code>
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>
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
<code>'Illuminate\Html\HtmlServiceProvider',</code>
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>
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>
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>
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>
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>
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>
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>
Dann behandeln wir das Formularübermittlungsereignis in der Route.
<code>Route::post('/articles', 'ArticlesController@store');</code>
Ü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>
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>
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>
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>
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>
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.

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

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

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



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

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 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.

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“.

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

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.

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