文件上传请求

一、上传文件。

1、定义一个类型为 file 的 input 标签。

2、在 input 标签中添加名为 changeHandler 的 @change 事件。

3、在 changeHandler 方法内用 this.file 对象接收上传的 File 文件。

changeHandler(e){
  // 打印文件  
  console.log(e.target.files[0]);
  // 接收文件  
  this.file = e.target.files[0];
}

 

二、、发送请求。

1、在 button 发送请求按钮中添加点击事件 sandAjax。

2、在 sandAjax 方法中将接收到的 file 文件进行处理,并发送到后台服务。

3、在sandAjax 中创建一个 FormData 对象,调用该对象中的 append("文件名", 文件) 方法将文件添加到 FormData 对象中。

  FormData 接口的append() 方法 会添加一个新值到 FormData 对象内的一个已存在的键中,如果键不存在则会添加该键。FormData.set 和 append() 的区别在于,如果指定的键已经存在, FormData.set 会使用新值覆盖已有的值,而 append() 会把新值添加到已有值集合的后面。

// 配置基础URL
this.$axios.defaults.baseURL = 'http://127.0.0.1:8888/';
// 创建表单对象 FormData
var fd = new FormData();
// 将新值 this.file 添加到 FormData 表单对象中
fd.append('file',this.file);

4、调用 axios 对象的 post 方法发送请求,并使用请求配置中的 onUploadProgress 对上传进度进行处理。

// 发送请求
this.$axios.post('upload',fd,{

    // 上传进度条
    onUploadProgress:(progressEvent)=>{
      // 对原生进度事件处理
    console.log(progressEvent);
    // 上传进度的值 = (文件当前上传的值/文件总值)X 100
    var progress = (progressEvent.loaded/progressEvent.total)*100;
    console.log(progress);
    // 更新 DOM 
    this.$nextTick(function(){
      // 记录文件上传的进度,并实时更新
      this.rate = Math.ceil(progress);
    }) 
  },
}) .then(res
=>{   console.log(res); }) .catch(err=>{   console.log(err); })

完整代码如下:

    <script type="text/javascript">
        var App = {
            template:` 
                <div>
                    选择文件:{{rate}}%
                    上传进度:
                    <input type="file" name='file' @change='changeHandler' />
                    <button @click='sendAjax'>发送请求</button>
                </div>
            `,
            data(){
                return{
                    file:{},
                    rate:0
                }
            },
            methods:{
                sendAjax(){
                    // 配置基础URL
                    this.$axios.defaults.baseURL = 'http://127.0.0.1:8888/';

                    // 创建表单对象 FormData
                    var fd = new FormData();
                    // 将新值 this.file 添加到 FormData 表单对象中
                    fd.append('file',this.file);

                    // 发送请求
                    this.$axios.post('upload',fd,{

                        // 上传进度条
                        onUploadProgress:(progressEvent)=>{
                            // 对原生进度事件处理
                            console.log(progressEvent);
                            // 上传进度的值 = (文件当前上传的值/文件总值)X 100
                            var progress = (progressEvent.loaded/progressEvent.total)*100;
                            console.log(progress);
                            // 更新 DOM 
                            this.$nextTick(function(){
                                // 记录文件上传的进度,并实时更新
                                this.rate = Math.ceil(progress);
                            }) 
                        },
                    })
                    .then(res=>{
                        console.log(res);
                    })
                    .catch(err=>{
                        console.log(err);
                    })
                },
                changeHandler(e){
                    console.log(e.target.files[0]);
                    this.file = e.target.files[0];
                }
            }
        }
        // 将axios挂载到Vue对象上
        Vue.prototype.$axios = axios

        new Vue({
            el:'#app',
            template:` 
                <App/>
            `,
            components:{
                App
            }
        });
    </script>

 

posted @ 2022-11-20 18:01  炒股沦为首负  阅读(86)  评论(0编辑  收藏  举报