本篇文章给大家分享的内容是关于laravel5.4框架中vue.js实现Ajax的表单提交错误验证,有一定的参考价值,希望可以帮助到有需要的朋友。
开始之前首先准备好开发环境,我们假设你已经安装好 Laravel,至于 Vue 的引入,请参考官方文档。
做好上述准备工作后就可以开始我们的开发了,本教程中我们将演示文章发布页面的表单验证。
首先在 routes/web.php 中新增两条路由规则:
Route::get('post/create', 'PostController@create'); Route::post('post/save', 'PostController@save');
然后在项目根目录下运行 Artisan 命令创建控制器 PostController:
php artisan make:controller PostController
在生成的控制器中新增两个方法用于处理路由请求:
public function create() { return view('post.create'); } public function save(Request $request) { // 设置验证规则 $this->validate($request, [ 'title' => 'required', 'body' => 'required' ]); }
接下来就要创建响应视图了,为了复用已有的样式风格和页面布局,我们先运行如下 Artisan 命令:
php artisan make:auth
这样我们就可以复用 Laravel 自带的认证功能页面布局了,创建视图文件 post/create.blade.php,并编辑文件内容如下:
@extends('layouts.app') @section('content') <div class="container"> <!--创建成功显示消息--> <div class="alert alert-success" v-if="submitted"> 创建成功! </div> <!--页面提交之后阻止刷新--> <form @submit.prevent="createPost" method="POST"> <legend>创建文章</legend> <!--如果title字段验证失败则添加.has-error--> <div class="form-group" :class="{'has-error':errors.title}"> <label>文章标题</label> <input type="text" name="title" class="form-control" v-model="post.title" value="{{ old('title') }}"> <!--如果验证失败通过FormError组件显示错误信息--> <form-error v-if="errors.title" :errors="errors"> @{{errors.title.join(',')}} </form-error> </div> <!--如果body字段验证失败则添加.has-error--> <div class="form-group" :class="{'has-error':errors.body}"> <label>文章正文</label> <textarea name="body" class="form-control" rows="5" v-model="post.body">{{ old('body') }}</textarea> <!--如果验证失败通过FormError组件显示错误信息--> <form-error v-if="errors.body" :errors="errors"> @{{errors.body.join(',')}} </form-error> </div> <button type="submit" class="btn btn-primary">创建文章</button> </form> </div> @endsection
这时访问页面页面为空,因为我们还没有定义 Vue 相关的数据变量,layouts.app 布局视图里引用了 app.js,而这个 js 由 resources/assets/js/app.js 编译而来,所以我们准备在这里定义 Vue 相关的代码:
var app = new Vue({ el: '#app', data: { post: { title: '', body: '' }, errors: [], submitted: false }, methods: { createPost: function () { var self = this; axios.post('/post/save', self.post).then(function(response) { // form submission successful, reset post data and set submitted to true self.post = { title: '', body: '', }; // clear previous form errors self.errors = ''; self.submitted = true; }).catch(function (error) { // form submission failed, pass form errors to errors array self.errors = error.response.data; }); } } });
我们在视图文件里还看到了 form-error,这其实是 Vue 里面的子组件,我们可以在 resources/assets/js/components 目录下创建这个新的组件文件,该目录下提供了一个样例 Example.vue,我们可以参照该样例编写一个新的 FormError.vue:
<template> <span class="help-block"> <slot></slot> </span> </template> <script> export default { props: ['errors'] } </script>
这里我们将父组件中的数据 errors 传递到了子组件中以便在子组件中显示错误信息。完成创建子组件后不要忘了在上述 resources/assets/js/app.js 中引入它:
Vue.component('form-error', require('./components/FormError.vue'));
这样,我们就完成了所有编码工作,接下来运行以下命令重新编译js:
npm run dev
当然在开发环境中,我们更倾向于使用 npm run watch,该命令会监听前端资源文件的更改然后重新编译,以避免每次修改后手动编译。
这样,在浏览器中访问 post/create 页面,就可以正常展示了:
什么都不填写,点击创建按钮,页面就能展示错误提示信息了:
填写相应字段之后再提交,则提示创建成功。
这样,我们在 Laravel 中完成了简单的,基于 Vue 实现的 Ajax 表单提交验证功能,个人感觉在提升开发效率方面还是很显著的
相关推荐:
Laravel 5.1框架中的ACL用户授权和权限检查功能的实现
Atas ialah kandungan terperinci laravel5.4框架中vue.js实现Ajax的表单提交错误验证. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Laravelsoftdeletesallow "penghapusan" withoutremovingRecordsfromthedatabase.toimplement: 1) usethesoftdeletestraitinyourmodel.2) usewithtrashed () toincludesoft-deletedrecordsinqueries.3)

Di Laravel, pulihkan rekod yang dipadam lembut menggunakan kaedah pemulihan (), dan memadamkan kaedah terpaksa () secara kekal. 1) Gunakan WithTrashed ()-> cari ()-> memulihkan () untuk memulihkan rekod tunggal, dan gunakan OnlyTrashed ()-> Restore () untuk memulihkan rekod tunggal. 2) Secara kekal memadam satu rekod dengan menggunakan WastRashed ()-> find ()-> forcedelete (), dan pelbagai rekod menggunakan OnlyTrashed ()-> forcedeLete ().

Anda harus memuat turun dan menaik taraf ke versi Laravel terkini kerana ia menyediakan keupayaan elokentorm yang dipertingkatkan dan ciri penghalaan baru, yang dapat meningkatkan kecekapan dan keselamatan aplikasi. Untuk menaik taraf, ikuti langkah -langkah berikut: 1. Sandarkan aplikasi semasa, 2. Kemas kini fail komposer.json ke versi terkini, 3. Jalankan arahan kemas kini. Walaupun beberapa masalah biasa mungkin ditemui, seperti fungsi yang dibuang dan keserasian pakej, isu -isu ini dapat diselesaikan melalui dokumentasi rujukan dan sokongan masyarakat.

YouShouldupdateTothelATestlaraverVersionWhentHeNefitsclearlyoutWeHiight

Laravel'ssoftdeleteFeatureCanbeEffectivelyTosafeguardDatabyfollowingspecificstepsandbestpractics.1) implementsoftDeletesingthesoftDeletestraitinyourmodel.2) useWithtrashed () toquerysoft-deletedrecorder.3)

Pemaju dengan cekap dapat menjejaki versi baru Laravel dan memastikan penggunaan pangkalan kod terkini dan paling selamat: 1. Gunakan coretan kod untuk memeriksa versi terkini dan membandingkannya dengan versi semasa, 2. Gunakan komposer dan laravel untuk pengurusan ketergantungan, 3. Melaksanakan ujian automatik untuk menangani konflik versi,

Versi terbaru Laravel (9.x) membawa kemas kini keselamatan yang penting, termasuk: 1) menampal kelemahan yang diketahui seperti serangan CSRF; 2) Meningkatkan keselamatan keseluruhan, seperti perlindungan CSRF dan pertahanan suntikan SQL. Dengan memahami dan menggunakan kemas kini ini dengan betul, anda dapat memastikan bahawa aplikasi Laravel anda sentiasa berada dalam keadaan paling selamat.

LaravelmigrationsareversionControlfordatabases, AllowingsChemAmanagementandevolution.1) theHelpMaintainTeamSynconSistencyCrossenvironments.2) usethemtoCreatetableslikethe'users'tableWithnesaryfields.3) ModifyExisTabeDdingFields


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Dreamweaver CS6
Alat pembangunan web visual

PhpStorm versi Mac
Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

SecLists
SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.
