詳解el-uploadaction組件使用方法

一、el-uploadaction組件簡介

el-uploadaction組件是基於element-ui的el-upload組件進行封裝的,主要是為了解決el-upload組件不能向後端node.js服務器發送自定義http請求的問題。使用el-uploadaction組件能夠方便地上傳文件、發送請求等操作。

二、el-uploadaction組件參數說明

el-uploadaction組件的參數基本跟el-upload組件一致,只是增加了以下參數:

1. action

表示上傳文件的後端接口地址,跟el-upload組件的action參數一致。

<el-uploadaction :action="uploadUrl">
  <el-button slot="trigger">上傳文件</el-button>
</el-uploadaction>

2. http-request

表示定義上傳文件的自定義請求方法,繼承el-upload原有方法,增加xhr及uploadEvent參數。

<el-uploadaction :action="uploadUrl" :http-request="uploadFile">
    <el-button slot="trigger">上傳文件</el-button>
</el-uploadaction>
uploadFile(file, callback) {
    const xhr = new XMLHttpRequest()
    xhr.upload.addEventListener('progress', (event) =>{
        const {loaded, total} = event.target
        const progress = parseInt((loaded/total)*100)
        this.progress = progress // 更新進度條顯示
    }, false)
    xhr.onreadystatechange = () => {
        if(xhr.readyState === 4 && xhr.status === 200) {
            callback(JSON.parse(xhr.responseText))
        }
    }
    xhr.open('POST', this.uploadUrl, true)
    const formData = new FormData()
    formData.append('file', file)
    xhr.send(formData)
}

3. upload-success

表示文件上傳成功後的回調函數,接收一個參數res,為後端返回的響應結果。

<el-uploadaction :action="uploadUrl" :http-request="uploadFile" @upload-success="uploadSuccess">
    <el-button slot="trigger">上傳文件</el-button>
</el-uploadaction>
uploadSuccess(res) {
    if(res.code === 200) {
        this.$message.success(`上傳成功`)
    } else {
        this.$message.error(`上傳失敗:${res.message}`)
    }
}

三、使用el-uploadaction實現文件上傳功能

1. 安裝element-ui組件

使用el-uploadaction需要安裝element-ui組件,可以在項目根目錄執行以下命令來安裝element-ui組件:

npm i element-ui -S

2. 引入el-uploadaction組件

在需要使用el-uploadaction組件的Vue組件文件中,引入el-uploadaction組件:

import ElUploadAction from 'el-uploadaction'

3. 註冊el-uploadaction組件

在Vue組件內註冊el-uploadaction組件:

components: {
  'el-uploadaction': ElUploadAction
}

4. 使用el-uploadaction組件

在Vue組件模板中使用el-uploadaction組件即可實現上傳文件功能了:

<template>
  <div>
    <el-uploadaction :action="uploadUrl" :http-request="uploadFile" @upload-success="uploadSuccess">
      <el-button slot="trigger">上傳文件</el-button>
    </el-uploadaction>
    <div v-if="progress">上傳進度:{{progress}}%</div>
  </div>
</template>

四、總結

el-uploadaction組件是一個非常方便的文件上傳組件,相比於el-upload組件,el-uploadaction組件可以更加靈活地設置後端上傳接口,自定義上傳請求方法,方便後端接口開發人員進行文件上傳功能的開發,同時配合element-ui組件庫使用,也能夠很好地解決文件上傳問題。

原創文章,作者:VCIH,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/136955.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
VCIH的頭像VCIH
上一篇 2024-10-04 00:16
下一篇 2024-10-04 00:17

相關推薦

  • Python中init方法的作用及使用方法

    Python中的init方法是一個類的構造函數,在創建對象時被調用。在本篇文章中,我們將從多個方面詳細討論init方法的作用,使用方法以及注意點。 一、定義init方法 在Pyth…

    編程 2025-04-29
  • Python符號定義和使用方法

    本文將從多個方面介紹Python符號的定義和使用方法,涉及注釋、變量、運算符、條件語句和循環等多個方面。 一、注釋 1、單行注釋 # 這是一條單行注釋 2、多行注釋 “”” 這是一…

    編程 2025-04-29
  • Python下載到桌面圖標使用方法用法介紹

    Python是一種高級編程語言,非常適合初學者,同時也深受老手喜愛。在Python中,如果我們想要將某個程序下載到桌面上,需要注意一些細節。本文將從多個方面對Python下載到桌面…

    編程 2025-04-29
  • Python匿名變量的使用方法

    Python中的匿名變量是指使用“_”來代替變量名的特殊變量。這篇文章將從多個方面介紹匿名變量的使用方法。 一、作為佔位符 匿名變量通常用作佔位符,用於代替一個不需要使用的變量。例…

    編程 2025-04-29
  • 百度地區熱力圖的介紹和使用方法

    本文將詳細介紹百度地區熱力圖的使用方法和相關知識。 一、什麼是百度地區熱力圖 百度地區熱力圖是一種用於展示區域內某種數據分布情況的地圖呈現方式。它通過一張地圖上不同區域的顏色深淺,…

    編程 2025-04-29
  • 如何修改ant組件的動效為中心

    當我們使用Ant Design時,其默認的組件動效可能不一定符合我們的需求,這時我們需要修改Ant Design組件動效,使其更加符合我們的UI設計。本文將從多個方面詳細闡述如何修…

    編程 2025-04-29
  • Ant Design組件的動效

    Ant Design是一個基於React技術棧的UI組件庫,其中動效是該組件庫中的一個重要特性之一。動效的使用可以讓用戶更清晰、更直觀地了解到UI交互的狀態變化,從而提高用戶的滿意…

    編程 2025-04-29
  • Matlab中addpath的使用方法

    addpath函數是Matlab中的一個非常常用的函數,它可以在Matlab環境中增加一個或者多個文件夾的路徑,使得Matlab可以在需要時自動搜索到這些文件夾中的函數。因此,學會…

    編程 2025-04-29
  • Python函數重載的使用方法和注意事項

    Python是一種動態語言,它的函數重載特性有些不同於靜態語言,本文將會從使用方法、注意事項等多個方面詳細闡述Python函數重載,幫助讀者更好地應用Python函數重載。 一、基…

    編程 2025-04-28
  • Python同步賦值語句的使用方法和注意事項

    Python同步賦值語句是Python中用來同時為多個變量賦值的一種方法。通過這種方式,可以很方便地同時為多個變量賦值,從而提高代碼的可讀性和編寫效率。下面從多個方面詳細介紹Pyt…

    編程 2025-04-28

發表回復

登錄後才能評論