cari
Rumahrangka kerja phpLaravellaravel5.4框架中vue.js实现Ajax的表单提交错误验证

本篇文章给大家分享的内容是关于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="{&#39;has-error&#39;:errors.title}">
                <label>文章标题</label>
                <input type="text" name="title" class="form-control" v-model="post.title" value="{{ old(&#39;title&#39;) }}">
                <!--如果验证失败通过FormError组件显示错误信息-->
                <form-error v-if="errors.title" :errors="errors">
                    @{{errors.title.join(&#39;,&#39;)}}
                </form-error>
            </div>
            <!--如果body字段验证失败则添加.has-error-->
            <div class="form-group" :class="{&#39;has-error&#39;:errors.body}">
                <label>文章正文</label>
                <textarea name="body" class="form-control" rows="5" v-model="post.body">{{ old(&#39;body&#39;) }}</textarea>
                <!--如果验证失败通过FormError组件显示错误信息-->
                <form-error v-if="errors.body" :errors="errors">
                    @{{errors.body.join(&#39;,&#39;)}}
                </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: &#39;#app&#39;,
    data: {
        post: {
            title: &#39;&#39;,
            body: &#39;&#39;
        },
        errors: [],
        submitted: false
    },
    methods: {
        createPost: function () {
            var self = this;
            axios.post(&#39;/post/save&#39;, self.post).then(function(response) {
                // form submission successful, reset post data and set submitted to true
                self.post = {
                    title: &#39;&#39;,
                    body: &#39;&#39;,
                };
                // clear previous form errors
                self.errors = &#39;&#39;;
                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: [&#39;errors&#39;]
    }
</script>

这里我们将父组件中的数据 errors 传递到了子组件中以便在子组件中显示错误信息。完成创建子组件后不要忘了在上述 resources/assets/js/app.js 中引入它:

Vue.component(&#39;form-error&#39;, require(&#39;./components/FormError.vue&#39;));

这样,我们就完成了所有编码工作,接下来运行以下命令重新编译js:

npm run dev

当然在开发环境中,我们更倾向于使用 npm run watch,该命令会监听前端资源文件的更改然后重新编译,以避免每次修改后手动编译。

这样,在浏览器中访问 post/create 页面,就可以正常展示了:

14987943320225.jpg

什么都不填写,点击创建按钮,页面就能展示错误提示信息了:

14987943736983.jpg

填写相应字段之后再提交,则提示创建成功。

这样,我们在 Laravel 中完成了简单的,基于 Vue 实现的 Ajax 表单提交验证功能,个人感觉在提升开发效率方面还是很显著的

相关推荐:

laravel的新特性之高阶消息传递

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!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Menguasai Laravel Soft Deletes: Amalan Terbaik dan Teknik LanjutanMenguasai Laravel Soft Deletes: Amalan Terbaik dan Teknik LanjutanMay 08, 2025 am 12:25 AM

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

Laravel Soft Deletes: Memulihkan dan Memadam Rekod secara kekalLaravel Soft Deletes: Memulihkan dan Memadam Rekod secara kekalMay 08, 2025 am 12:24 AM

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

Siaran Laravel semasa: Muat turun dan naik taraf hari ini!Siaran Laravel semasa: Muat turun dan naik taraf hari ini!May 08, 2025 am 12:22 AM

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.

Laravel: Bilakah saya harus mengemas kini versi terakhir?Laravel: Bilakah saya harus mengemas kini versi terakhir?May 08, 2025 am 12:18 AM

YouShouldupdateTothelATestlaraverVersionWhentHeNefitsclearlyoutWeHiight

Laravel Soft Delete: Cara Mencegah Kerugian Data TetapLaravel Soft Delete: Cara Mencegah Kerugian Data TetapMay 08, 2025 am 12:04 AM

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

Tracker Versi Laravel: Sentiasa Ketahui Siaran TerkiniTracker Versi Laravel: Sentiasa Ketahui Siaran TerkiniMay 07, 2025 pm 06:25 PM

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,

Laravel Versi Terakhir: Kemas kini KeselamatanLaravel Versi Terakhir: Kemas kini KeselamatanMay 07, 2025 pm 05:25 PM

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.

Panduan Terbaik untuk Migrasi Laravel: Pengurusan Struktur Pangkalan DataPanduan Terbaik untuk Migrasi Laravel: Pengurusan Struktur Pangkalan DataMay 07, 2025 pm 05:05 PM

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

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

Alat panas

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

SecLists

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

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

MinGW - GNU Minimalis untuk Windows

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.