一,相关文档
https://learnku.com/docs/laravel/10.x/filesystem/14865#481e03
二,前端vue代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 |
< template >
< div >
请选择上传幻灯图片:
< input type = "file" id = "back" ref = "backfile" multiple @ change = "handleFile" />
< div id = "imglist" style = "width:100%;" >
< div v-for = "(item,i) in selFiles" :key = "i" style = "float:left;margin-left: 20px;margin-top: 20px;height:150px;position:relative;" >
< img :src = "item.fileimg" style = "height:150px;" />
< div @ click = "delqueue(i)" style = "position:absolute;width:30px;height:30px;line-height:30px;border-radius:15px;top:-15px;right:-15px;background:#ff0000;" >x</ div >
</ div >
</ div >
< input type = "button" value = "上传" @ click = "upload" />
</ div >
</ template >
< script >
import {ref} from "vue"
import axios from 'axios';
export default {
name: "MultiUploadImg",
setup() {
//选中的图片文件,保存在数组中
const selFiles = ref([]);
//选中图片后的处理
const handleFile = () => {
let filePaths = window.event.target.files;
//清空原有缩略图
if (filePaths.length === 0) {
//未选择,则返回
return
} else {
//清空数组中原有图片
selFiles.value.length = 0;
}
//把新选中的图片加入数组
for( var i=0;i< filePaths.length ; i++ ){
let file = filePaths [i];
let one = {
fileimg:URL.createObjectURL(file), //预览用
file:file,
}
selFiles.value.push(one);
}
}
//从上传数组中删除
const delqueue = (index) => {
if (confirm("确定从上传队列中删除当前图片?")) {
selFiles.value.splice(index,1);
}
}
//上传
const upload = () => {
//判断是否选中文件
var file = selFiles.value[0].file;
if (typeof(file) === "undefined") {
alert("请在上传前先选中文件!");
return;
}
// 创建一个表单数据
var data = new FormData();
//遍历文件,添加到form
for( var i=0;i< selFiles.value.length ; i++ ){
let fileOne = selFiles .value[i].file;
data.append("img[]",fileOne);
}
let url = "/api/news/multiimgadd" ;
//axios上传文件
axios({
method:"post",
url:url,
data:data,
headers:{'Content-Type': 'multipart/form-data'},
}).then((res) => {
if (res.data.code == 0) {
let data = res.data.data;
let imageUrl = data.urls;
alert("success:image:"+imageUrl);
} else {
alert("error:"+res.data.msg);
}
}
).catch(err=>{
alert('网络错误:'+err.message);
});
}
return {
handleFile,
selFiles,
delqueue,
upload,
}
}
}
</ script >
< style scoped>
</ style >
|
三,后端php代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 |
//多图片上传
public function multiImgAdd(Request $request ) {
if ( $request ->hasFile( 'img' )) {
$str = "" ;
//遍历文件
foreach ( $request ->file( 'img' ) as $index => $e ) {
//得到扩展名
$ext = $e ->getClientOriginalExtension();
$filename = time().rand(). "." . $ext ;
$baseDir = "/var/www/html/digImage" ;
//保存图片到指定目录
$e ->move( $baseDir , $filename );
//返回url
$url = "http://192.168.219.6/digImage/" . $filename ;
if ( $str == '' ) {
$str = $url ;
} else {
$str .= ";" . $url ;
}
}
return Result::Success([ 'urls' => $str ]);
} else {
// 回到上一个页面
//return back();
return Result::ErrorCode(10024, '图片文件未上传' );
}
}
|
说明:刘宏缔的架构森林—专注it技术的博客,
网站:https://blog.imgtouch.com
原文: https://blog.imgtouch.com/index.php/2023/10/29/laravel-duo-tu-pian-shang-chuan-10-27-qian-duan-vue/
代码: https://github.com/liuhongdi/ 或 https://gitee.com/liuhongdi
说明:作者:刘宏缔 邮箱: 371125307@qq.com
四,测试效果:
五,查看laravel框架的版本:
liuhongdi@lhdpc:/data/laravel/dignews$ php artisan --version
Laravel Framework 10.27.0
标签:laravel,vue,selFiles,10.27,data,let,file,div,上传
From: https://www.cnblogs.com/architectforest/p/17797025.html