最近在學習axios,然後專案就用到了,所以這篇文章主要給大家介紹了關於vue中利用axios實現文件上傳進度的實時更新的相關資料,文中先對axios進行了簡單的介紹,方法大家理解學習,需要的朋友們下面一起學習學習吧。
axios 簡介
axios 是基於Promise 用於瀏覽器和nodejs 的HTTP 用戶端,它本身俱有以下特徵:
從瀏覽器建立XMLHttpRequest
#從node.js 發出http 請求
引入方式:
$ npm install axios //使用淘宝源 $ cnpm install axios //或者使用cdn: <script src="https://unpkg.com/axios/dist/axios.min.js"></script>
Vue.use () ,所以只能在每個需要發送請求的元件中即時引入。
import axios from 'axios' Vue.prototype.$http = axios
methods: { postData () { this.$http({ method: 'post', url: '/user', data: { name: 'xiaoming', info: '12' } }) }
vue使用axios實作檔案上傳進度即時更新
XHR二級增加了progress事件,我們可以據此在瀏覽器接收新數據期間添加實時數據進度條,從而使得交互更加友好vue模板
<p class="progress" @click="upload" :style="{backgroundImage:'linear-gradient(to right,#C0C7CB 0%,#C0C7CB '+progress+',#E1E6E9 '+progress+',#E1E6E9 100%)'}">
vue-js
var form = new FormData() form.append('file', vm.$refs.upload.files[0]) form.append('id', id) form.append('type', type) var config = { onUploadProgress: progressEvent => { var complete = (progressEvent.loaded / progressEvent.total * 100 | 0) + '%' this.progress = complete } } axios.post(`api/uploadFile`, form, config).then((res) => { if (res.data.status === 'success') { console.log('上传成功') } })
在Node.js中呼叫fs.renameSync出現錯誤問題?
以上是在vue中使用axios實作檔案上傳的詳細內容。更多資訊請關注PHP中文網其他相關文章!