iview Upload組件多個文件上傳

使用  iview Upload 上傳組件 手動上傳 包括單個文件和多個文件ios

思路:建立一個數組 把須要上傳的文件 push到這個數組裏面web

1.引用組件axios

2.手動上傳,根據官方文檔 設置:before-upload ="handleUpload"等於false 數組

(1).:before-upload 是 iview Upload 上傳組件的一個屬性 設置返回值爲 false 能夠阻止默認上傳方式(自動上傳模式)服務器

(2).handleUpload 是方法  *備註:代碼在最後面app

3.上傳方法     iview

//建立 formData 對象

                    let formData = new FormData();
                    //向 formData 對象中添加文件--這是其餘參數
                    formData.append('jsid', _jsid);

                    //多個文件上傳----------重點----須要吧已經存儲到本地的文件加入 formData因此這裏用for循環

                    for(var i=0; i< that.file.length; i++){  
                      formData.append("uploadFile",that.file[i]);   // 文件對象    
                    } 

 

HTML代碼以下:post

<FormItem label="應標資料" v-show="islook">
                    <template>
                        <Upload
                            multiple
                            ref="upload"
                            type="drag"
                            :format="['docx','doc','txt', 'pdf']"
                            :max-size="5000"
                            :before-upload="handleUpload"
                            :action="http">
                            <div style="padding: 20px 0">
                                <Icon type="ios-cloud-upload" size="52" style="color: #3399ff"></Icon>
                                <p>點擊或者拖拽到這次上傳文件</p>
                            </div>
                        </Upload>
                        <div>
                            <ul class="file-list" v-for="(list,index) in file" :key="index">
                                <li>文件名: <span style="font-size:15px;">{{ list.name }}</span> <Icon type="ios-close" size="20" style="float:right;" @click="delFileList(index)"></Icon></li>
                            </ul>
                        </div>
                    </template>
                </FormItem>


                <FormItem v-show="islookshenghe">
                    <h3>已經提交數據-正在等待審覈</h3>
                    <Button type="primary" @click="gobackfanhui">返回</Button>
                </FormItem>

                <FormItem v-show="islook">
                    <Button type="primary" :loading="loading2" icon="ios-power" @click="upload">
                        <span v-if="!loading2">接受並提交應標信息</span>
                        <span v-else>正在上傳文件中...</span>
                    </Button>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;

                    <p style="color:red;font-size:15px;" v-show="isfiletihsi">請上傳文件</p>
                </FormItem>

 

JS代碼ui

delFileList(index){
                let that = this;
                that.file.splice(index, 1);
                
                console.log(that.file);
            }

 

handleUpload (file) {
                let that = this;
                if(that.file.length >= 5){
                    this.$Message.info("最多隻能上傳5個文件");
                }else{
                    that.file.push(file);
                }
                return false;
            }
axios提交方法代碼:
upload(){
                let that = this;
                let _jsid = that.$route.query.id;
                if(that.file.length > 0){
                    that.loading2 = true;
                    //建立 formData 對象
                    let formData = new FormData();
                    //向 formData 對象中添加文件
                    formData.append('jsid', _jsid);

                    //多個文件上傳
                    for(var i=0; i< that.file.length; i++){  
                      formData.append("uploadFile",that.file[i]);   // 文件對象    
                    } 

                    let config = {
                      headers: {
                        'Content-Type': 'multipart/form-data'
                      }
                    }

                    axios.post(that.http + "/shweb/gys/gysmsge/gysuploads.action", formData, {
                                timeout: 10000,
                                headers: {
                                    'Content-Type': 'multipart/form-data'
                                }
                            }).then(function (rdata) {
                                that.loading2 = false;
                                if(rdata.data == "0"){
                                    that.islook = false;
                                    that.islookshenghe = true;
                                }
                                console.log(rdata);
                            }).catch(function (error) {
                                that.loading2 = false;
                              that.$Message.error('服務器錯誤' + error);
                            });
                }else{
                    that.$Message.error("請至少上傳一個文件");
                }
            }
相關文章
相關標籤/搜索