0

0

laravel Livewire如何实现文件上传和进度条_Laravel Livewire文件上传与进度条实现方法

下次还敢

下次还敢

发布时间:2025-10-12 18:00:03

|

1023人浏览过

|

来源于php中文网

原创

Laravel Livewire 支持文件上传与进度条显示,需配置临时路径、设置磁盘并创建组件,通过 WithFileUploads 实现上传功能,在 Blade 中结合 wire:loading 与 JavaScript 钩子模拟进度条,提升用户体验。

laravel livewire如何实现文件上传和进度条_laravel livewire文件上传与进度条实现方法

Laravel Livewire 提供了简洁的方式处理文件上传,同时配合前端可以实现上传进度条。整个过程无需手动编写大量 JavaScript,适合在现代化 Laravel 项目中快速集成。

1. 配置 Livewire 文件上传支持

Livewire 原生支持文件上传,但需要确保配置正确:

  • config/livewire.php 中确认临时上传路径设置(默认为 storage/app/livewire-tmp)
  • 确保该目录可写:storage/app/livewire-tmp
  • filesystems.php 中设置默认磁盘(如 public 或 s3)
  • 发布 Livewire 资源(如有需要):php artisan livewire:publish --assets

2. 创建支持文件上传的 Livewire 组件

使用 Artisan 命令创建组件:

php artisan make:livewire FileUpload

编辑生成的组件类:

namespace App\Livewire;

use Livewire\Component; use Livewire\WithFileUploads;

class FileUpload extends Component { use WithFileUploads;

public $file;
public $uploadProgress = 0;

public function save()
{
    $this->validate([
        'file' => 'required|file|max:10240', // 最大 10MB
    ]);

    $path = $this->file->storeAs(
        'uploads',
        $this->file->getClientOriginalName(),
        'public'
    );

    $this->reset('file');
    session()->flash('message', '文件上传成功!');
}

public function updatedFile()
{
    // 可在这里触发上传开始提示
}

public function render()
{
    return view('livewire.file-upload');
}

}

3. 构建 Blade 视图并添加进度条

Livewire 不直接提供上传进度数值,但可通过监听 xhr 请求模拟进度条。

无涯·问知
无涯·问知

无涯·问知,是一款基于星环大模型底座,结合个人知识库、企业知识库、法律法规、财经等多种知识源的企业级垂直领域问答产品

下载

创建视图 resources/views/livewire/file-upload.blade.php

    {{-- 显示验证错误 --}}
    @error('file') {{ $message }} @enderror

    {{-- 上传中显示进度条 --}}
    
0%
@if (session()->has('message'))
{{ session('message') }}
@endif

Livewire.hook('message.sent', () => {
    if (Livewire.hook('request.url').includes('file')) {
        let interval = setInterval(() => {
            if (progressBar.value < 90) {
                progressBar.value += 1;
                progressText.textContent = Math.round(progressBar.value) + '%';
            } else {
                clearInterval(interval);
            }
        }, 200);
    }
});

Livewire.hook('message.received', () => {
    progressBar.value = 100;
    progressText.textContent = '100%';
});

Livewire.hook('message.failed', () => {
    progressText.textContent = '上传失败';
});

});

4. 样式优化与用户体验

可以为进度条添加简单样式提升视觉效果:


也可替换为 div 模拟的进度条,便于自定义外观。

基本上就这些。Livewire 的文件上传机制结合简单的 JS 钩子,就能实现带进度反馈的体验。虽然不能精确获取服务器传输字节,但模拟进度已能满足大多数场景。注意大文件建议配合后端分片或使用专用上传库增强稳定性。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2679

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1660

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1516

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1419

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1235

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1488

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

java用途介绍
java用途介绍

本专题整合了java用途功能相关介绍,阅读专题下面的文章了解更多详细内容。

0

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.9万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 8.4万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号