如何解决Laravel 8:如何使用Sweet Alert消息进行表单错误报告
我有一个登录刀片,其中包含一个表格:
<form method="POST" action="{{ route('login') }}">
@csrf
<div class="field">
<span class="fas fa-user"></span>
<input type="email" name="email" required>
<label style="right:0;" class="BFarnaz">Email</label>
@error('email')
alert()->success('{{ $message }}','message')->persistent('Ok');
@enderror
</div>
<div class="field">
<span class="fas fa-lock"></span>
<input type="password">
<label style="right:0;" class="BFarnaz">Password</label>
@error('password')
alert()->success('{{ $message }}','message')->persistent('Ok');
@enderror
</div>
<button class="BJadidBold">Login</button>
</form>
我还成功安装了Sweet Alert package,现在我想用它向用户显示表单错误:
@error('password')
alert()->success('{{ $message }}','message')->persistent('Ok');
@enderror
但是这种方法是错误的,不幸的是,我不知道这样做的正确方法是什么...
所以,如果您知道正确的方法,请帮帮我。
谢谢。
解决方法
我不确定您是否通过NPM引入了甜蜜警报,并通过CDN获得了该警报,是通过npm进行了提取和复制,还是通过webpack进行了编译。 为了这个示例,我将仅使用CDN。
首先,将CDN包含到您的项目中,以便其可用。
您可以在主刀片服务器文件中执行此操作,也可以通过@push('scripts_stacked')
进行推送,并在主刀片服务器中放入@stack('scripts_stacked')
来接收推送的脚本。
让我们将@push('scripts_stacked')
添加到您的master.blade.php
或我们的主刀片中删除的是这样的名称文件:
<!DOCTYPE html>
<html lang="{{ str_replace('_','-',app()->getLocale()) }}">
<head>
...
</head>
<body>
...
@yield('body')
...
@stack('footer_scripts_stacked')
</body>
</html>
一旦有了它,那么从中扩展的主刀片文件就可以接收堆叠的JS,可以使用以下内容在正在处理的刀片文件中进行处理:
@push('scripts_stacked')
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/sweetalert/2.1.2/sweetalert.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/promise-polyfill"></script>
@endpush
@if (session('message'))
@push('scripts_stacked')
<script type="text/javascript">
$(function() {
{{-- Toast Example --}}
const Toast = Swal.mixin({
toast: true,position: 'top-end',showConfirmButton: false,timer: 5000,timerProgressBar: true,onOpen: (toast) => {
toast.addEventListener('mouseenter',Swal.stopTimer)
toast.addEventListener('mouseleave',Swal.resumeTimer)
}
});
Toast.fire({
icon: 'info',title: '{{ session('message') }}',})
{{-- Regular SWAL2 Example --}}
Swal.fire({
title: 'Hey!',text: '{{ session('message') }}',icon: 'info',confirmButtonText: 'Okay'
})
});
</script>
@endpush
@endif
@if (session('success'))
@push('footer_scripts_stacked')
<script type="text/javascript">
$(function() {
{{-- Toast Example --}}
const Toast = Swal.mixin({
toast: true,Swal.resumeTimer)
}
});
Toast.fire({
icon: 'success',title: '{{ session('success') }}',})
{{-- Regular SWAL2 Example --}}
Swal.fire({
title: 'Success!',text: '{{ session('success') }}',icon: 'success',confirmButtonText: 'Okay'
})
});
</script>
@endpush
@endif
@if (session('error'))
@push('footer_scripts_stacked')
<script type="text/javascript">
$(function() {
{{-- Toast Example --}}
const Toast = Swal.mixin({
toast: true,Swal.resumeTimer)
}
});
Toast.fire({
icon: 'error',title: '{{ session('error') }}',})
{{-- Regular SWAL2 Example --}}
Swal.fire({
title: 'Error!',text: '{{ session('error') }}',icon: 'error',confirmButtonText: 'Okay'
})
});
</script>
@endpush
@endif
,
我使用了不同的软件包realrashid/sweet-alert,因为它使用了SweetAlert2而不是SweetAlert。不要忘记已经包含了jQuery。
安装后不要忘记发布资产:
from sympy import *
omega = symbols('omega')
a = symbols('a1 a2')
b = symbols('b1 b2')
class A(Function):
@classmethod
def eval(self,x):
if isinstance(x,Symbol):
return
else:
return a[x]
class B(Function):
@classmethod
def eval(self,Symbol):
return
else:
return b[x]
# indexing starts at 0
numerator = -summation(B(omega)*A(omega),(omega,1))
denominator = summation((B(omega)-1)*A(omega),1))
result = numerator/denominator
在主布局刀片中:
php artisan sweetalert:publish
控制器中的示例:
@include('sweetalert::alert')
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。