vue文件上传功能_vue如何自定义组件

vue文件上传功能_vue如何自定义组件vue的文件上传组件upload,拥有支持多种格式文件上传,单文件多文件等都支持,许多项目现在都少不了文件上传功能,但是vue的upload组件如果直接引用,肯定也有一些不方便之处,有的时候需要传参数,需要手动触发上传方法,而不是选择了文件就上传,所以结合我项目实例,写一vue自定义文件上传的实现,包括前端和后台的处理以及参数的接收。一、先认识一下vue的upload组件,官网链接ht…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

vue的文件上传组件 upload ,拥有支持多种格式文件上传,单文件多文件等都支持,许多项目现在都少不了文件上传功能,但是vue 的upload组件如果直接引用,肯定也有一些不方便之处,有的时候需要传参数,需要手动触发上传方法,而不是选择了文件就上传,所以结合我项目实例,写一vue 自定义文件上传的实现,包括前端和后台的处理以及参数的接收。

一、先认识一下vue 的upload组件,官网链接 http://element-cn.eleme.io/#/zh-CN/component/upload,这里不多做解释,大家自己看

二、使用

这个组件有多种样式,我在这里只展示一种,如图所示

vue文件上传功能_vue如何自定义组件

代码:

class=”upload-demo”

drag

:action=”url”        //此处的url是从父页面传过来的动态值,不同页面引用,可能请求的后台地址不一样,所以定义了一个变量接收

:multiple=”false”

:before-upload=”beforeUpload”     //上传之前调用的方法,验证,格式限制等等,大小限制都可以在这个方法中实现

:limit=1     //个数限制

:auto-upload=”false”  //是否立即上传,默认为true

:on-exceed=”handleExceed” //文件超出个数限制时的钩子

:http-request=”uploadFile”>  //自定义提交方法

将文件拖到此处,或
点击上传
只能上传.xlsx文件
一次只能上传一个文件

export default {

props:{visible:false, //父页面传递参数

initData:{}, //父页面传递参数

url:””  //父页面传递上传url

},

watch: {  //监听参数值改变

initData(newValue,oldValue){

this.getData(newValue);

console.log(“newValue2333”,newValue);

}

},

data() {

return {

params:{},

}

},

mounted(){

},

methods:{

close() {

this.$emit(“update:visible”, false);

},

beforeUpload (file) {  //设置只能上传excel文件

console.log(‘beforeUpload’)

console.log(file.type)

const isExcel = file.type === ‘application/vnd.openxmlformats-officedocument.spreadsheetml.sheet’

if(isExcel){

return true;

}else{

this.$message.warning(`只能上传excel文件`)

return false;

}

},

// 上传文件个数超过定义的数量

handleExceed (files, fileList) {

this.$message.warning(`当前限制选择 1 个文件,请删除后继续上传`)

},

// UploadUrl:function(){

// return

// },

getData(initData){   //参数值改变重新赋值

this.params=initData;

},

//确认上传

submitUpload(){

this.$refs.upload.submit();

},

//开始上传文件

uploadFile(content){

console.log(“uploadFile”,content);

const formData=new FormData();

formData.append(“file”,content.file);

formData.append(“params”,this.params);    //后台接收param时可以vue可以先将params转成json字符串,后台接收一个json字符串再遍历,自己百度

//发送请求

console.log(this.params);

this.commonPost({

url:content.action,

params:formData,

timeout:2000,

}).then(data=>{

this.$message({

type:”success”,

message:”上传文件成功”

});

//关闭上传弹出框

this.close();

})

}

}

};

由于我这个是做的一个公共组件,可以作为其他页面的一个组件给放进去,所以会有一些特别之处,,大部分在代码中都有注释。

三、父页面部分代码

   在需要的地方引用这句话,

import InportExcel from ‘@/api/pfm/common/InportExcel’;   //引入InportExcel

watch:{

headerId:function(val,oldval){

if(val && val != -1){

this.fileData={};          //参数监听

this.fileData.currentHeaderId=val; //参数赋值

this.urlString=” http://localhost:8080/pfm/file/upFile”; //url赋值

}

}

components:{      //InportExcel注册

InportExcel:InportExcel

}

四、后台代码处理

1、controller

@PostMapping(“/upFile”)

public Object upLoadFile(@RequestParam(“file”) MultipartFile file,@RequestParam(“params”) String params,

HttpServletResponse response,HttpServletRequest request){

Workbook workbook=null;

try{

if(params!=null){

JSONObject json=JSONObject.parseObject(params);

if(json.containsKey(“currentHeaderId”)){

System.out.println(json.get(“currentHeaderId”).toString());

}

}

workbook= fileService.uploadFile(file,request,response);

}catch (Exception e){

logger.info(e.getMessage());

}

return workbook;

}

2、service实现

@Override

public Workbook uploadFile(MultipartFile file, HttpServletRequest request, HttpServletResponse response) throws IOException {

checkFile(file);

System.out.println(file);

return getWorkBook(file);

//接收文件

}

public static void checkFile(MultipartFile file) throws IOException {

if(null==file){

logger.info(“文件不存在”);

throw new FileNotFoundException(“文件不存在”);

}

String fileName=file.getOriginalFilename();

System.out.println(fileName.endsWith(“xls”));

if(!fileName.endsWith(“xls”)&&!fileName.endsWith(“xlsx”)){

logger.info(“不是excel文件”);

throw new IOException(fileName+”不是excel文件”);

}

}

public static Workbook getWorkBook(MultipartFile file){

String fileName=file.getOriginalFilename();

Workbook workbook=null;

try{

InputStream is=file.getInputStream();

if(fileName.endsWith(“xls”)){

workbook=new HSSFWorkbook(is);

}else if(fileName.endsWith(“xlsx”)){

workbook=new XSSFWorkbook(is);

}

}catch (IOException e){

logger.info(e.getMessage());

}

return workbook;

}

3、注,本次后台代码只针对excel文件,如果是其他文件,也可以进行百度,处理方法很简单

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/170646.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月15日 下午11:36
下一篇 2022年8月15日 下午11:36


相关推荐

  • JavaFX横幅类游戏开发 教训 游戏贴图

    JavaFX横幅类游戏开发 教训 游戏贴图

    2022年1月3日
    49
  • 完整的vue开发环境搭建教程

    完整的vue开发环境搭建教程一 安装 node js https nodejs org en 下载完毕后 可以安装 node 建议不要安装在系统盘 如 C 输出版本号则安装成功 node v 输出版本号则安装成功二 设置 nodejsprefix 全局 和 cache 缓存 路径查看 npm 安装目录 npmroot g 查看 npm 的 prefix 和 cache 路径配置信息 npmconfigget 修改全局和缓存路径 1 先在设置路径目录

    2026年3月26日
    3
  • ListView-1(包括常用属性和方法)「建议收藏」

    ListView-1(包括常用属性和方法)「建议收藏」Spinner-下拉列表在vakues里建立一个arrays.xml文件,为listview提供数据,也可以写在string.xml文件里activity_main.xml布局android:

    2022年7月4日
    21
  • windows上mysql安装教程_mysql和oracle的区别

    windows上mysql安装教程_mysql和oracle的区别前期在windows电脑尝试安装mysql,经历诸多不顺,特把安装详细步骤以及遇见的问题记录下来,提供给有需者使用。配置过程主要分为五个步骤,如下所示:(1)确认本地是否安装mysql(2)下载mysql安装包(3)添加配置文件并安装mysql(4)修改mysql密码(5)配置环境变量【确认本地是否安装mysql】(1)按【win+r】快捷键打开运行;(2)输入services.msc,点击【确定】;(3)在打开的服务列表中查找mysql服务,如果没有mysql服务,说明本机没有安装my

    2025年11月15日
    4
  • 9 python 匹配开头和结尾

    9 python 匹配开头和结尾1.匹配开头和结尾代码 功能^ 匹配字符串开头$ 匹配字符串结尾示例1:^需求:匹配以数字开头的数据importre#匹配以数字开头的数据match_obj=re.match(“^\d.*”,”3hello”)ifmatch_obj:#获取匹配结果print(match_obj.group())else:print(“匹配失败”)运行结果:3hello示例2:$需求:匹配以数字结尾的数据importre#匹配以数字结尾的

    2022年7月25日
    21
  • React项目的国际化

     最近做的react项目需要支持国际化,网上查了一下,发现一款很好的插件“react-intl-universal”,由阿里巴巴团队开发,这款插件是原先的国际化插件“react-intl”的升级版,“react-intl”因为一些“致命”缺陷现已被其取代,npm官网有罗列原因,有兴趣的可以去了解一下。下面具体介绍一下这款插件的使用方法。1.安装npminstallreact-i…

    2022年4月12日
    45

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号