Bootstrap

el-upload上传时的file-List的基本用法

关于el的file-List用法官网有写,但是一直搞不懂的时url到底是什么地址,跟上传地址有什么区别。

于是百度下,有人这么写,意思是url就是文件的地址。难道官网的url就是网上图片的地址?有人问了,那要是本地地址呢,这个url怎传?

html:

<el-upload
  action="https://192.168.1.1:8888/xxx上传接口"
  :file-list="fileList"
  <i class="el-icon-plus"></i>
</el-upload>

vue/js:

data(){
	return{
		fileList: []
	}
}
methods:{
	update(){
		fileList.push({name: "123.jpg"  url: "图片地址"})

	}
}

-------------------------------------割--------------------------------------------------------------------最后问题来了,url到底时什么地址?

在点击选择文件时@change,就已经发请求了,后端会给我文件服务器的上传路径(https://192.168.1.1:8888/上传接口 )+ 会给一个唯一名称值给我(当然前端也可以自己生成,但是后端要做记录,所以它就自己生成了),这时后端传过来的就有了上传接口,我绑定在了:action中。哪个唯一值我就放在fileList的name中,

我尝试了几种url:1.设置为空,如url:""。2:apk的本地路径,如:localhos(127.0.0.1、本地IP) d:软件APKtest按键精灵.apk 。很显然都上传失败了。

最后一种就是把上传接口地址放到url里面,发现没报错,我还以为成功了。所以

html:

<el-upload
  action="https://192.168.1.1:8888/xxx上传接口"
  :file-list="fileList"
  @change="qingqiu"
  <i class="el-icon-plus"></i>
</el-upload>

vue

data(){
	return{
		fileList: []
	}
}
methods:{
     //选择文件时我发个请求,让后端告我服务器地址
    qingqiu(){
        send();//这个是请求指令
    }	
        
    data(e){//接收后端反馈回来的参数,自己拆分,这里随便写得接收方法,你怎么接收就怎么写
        
        e.url//假如这个是传过来得文件服务器地址,即上传路径
        e.name//假如这是传过来得唯一名称,你也可以自己命名:parser.file.name20210624094432988
            
        fileList.push(name:e.name,url:e.url)

    }
    
   quedingButton(){//最后确定上传
        
        this.$refs.upload.submit();

   }
}

我们看看效果:我们选择一个APK文件,如下图所示,原来就是显示“按键精灵.apk”,但是我们通过file-List就变为了我们上传时修改的名称。

然后这个“按键精灵.apk”就根据name的值变为了“parser.file.name20210624094432988”这样就上传到文件服务器那里也是显示“parser.file.name20210624094432988.apk”。

这个file-List方法的name仅修改选择后的名称有什么用啊。

这个还不如使用:on-success="handleAvatarSuccess"这个钩子,如:

handleAvatarSuccess(res, file, fileList) {
            console.log("上传成功的钩子", file, fileList);
            file.name="parser.file.name20210624094432988.apk";
}

效果跟上面一样的。所以file-List上传后显示用的而已。

问题又来了,

1.我们这么做以后,很明显给用户的感觉不对,如果要命名后的文件不显示,还是显示原来的,如:按键精灵.apk?

答,不要file-List就行了。

2.我们想上传时是想修改apk的名称到服务器保存,怎么做?

答:首先文件服务器得支持传参,我们传参给它,它自己生成和命名。我们就可以开始传参了,方法见:https://blog.csdn.net/bbs11007/article/details/118191226

;