ElementUI+Vue 計(jì)算文件上傳的md5

廢話不多說,直接上代碼雹姊,有問題直接提問



<template>
  <el-dialog title="添加圖片"
             :visible.sync="visible"
             width="500px">
    <div class="upload-card">
      <el-upload drag
                 action=""
                 :file-list="fileList"
                 :on-change="handleChange"
                 :show-file-list="false"
                 accept="image/png,image/jpg,image/jpeg">
        <i class="el-icon-upload"></i>
        <div class="el-upload__text">將文件拖到此處怔毛,或<em>點(diǎn)擊上傳</em></div>
      </el-upload>
    </div>
  </el-dialog>
</template>

<script>
import SparkMD5 from 'spark-md5'
export default {
  name: 'md5-image-dialog',
  props: {
  },
  data () {
    return {
      visible: false,
      fileList: []
    }
  },
  methods: {
    // 計(jì)算md5
    handleChange (file, fileList) {
      const blobSlice = File.prototype.slice || File.prototype.mozSlice || File.prototype.webkitSlice
      const fileReader = new FileReader()
      const chunkSize = 2097152
      const chunks = Math.ceil(file.size / chunkSize)
      let currentChunk = 0
        //注意點(diǎn),網(wǎng)上都是 這一步都是有問題的生兆, SparkMD5.ArrayBuffer() 
      const spark = new SparkMD5.ArrayBuffer()
      fileReader.onload = function (e) {
        spark.append(e.target.result)
        currentChunk++
        if (currentChunk < chunks) {
          loadNext()
        } else {
          const sparkEnd = spark.end()
            //計(jì)算后的結(jié)果
          console.log('computed hash', sparkEnd)
        }
      }
      fileReader.onerror = function () {
        console.warn('FileReader error.')
      }
      function loadNext () {
        const start = currentChunk * chunkSize
        const end = ((start + chunkSize) >= file.size) ? file.size : start + chunkSize
        // 注意這里的 fileRaw
        fileReader.readAsArrayBuffer(blobSlice.call(file.raw, start, end))
      }
      loadNext()
    }
  }
}
</script>

<style lang="sass" scoped>
.upload-card
  display: flex
  justify-content: center
</style>

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末叭喜,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子靖榕,更是在濱河造成了極大的恐慌标锄,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,542評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件序矩,死亡現(xiàn)場(chǎng)離奇詭異鸯绿,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)簸淀,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門瓶蝴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人租幕,你說我怎么就攤上這事舷手。” “怎么了劲绪?”我有些...
    開封第一講書人閱讀 158,021評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵男窟,是天一觀的道長(zhǎng)盆赤。 經(jīng)常有香客問我,道長(zhǎng)歉眷,這世上最難降的妖魔是什么牺六? 我笑而不...
    開封第一講書人閱讀 56,682評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮汗捡,結(jié)果婚禮上淑际,老公的妹妹穿的比我還像新娘。我一直安慰自己扇住,他們只是感情好春缕,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,792評(píng)論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著艘蹋,像睡著了一般锄贼。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上女阀,一...
    開封第一講書人閱讀 49,985評(píng)論 1 291
  • 那天宅荤,我揣著相機(jī)與錄音,去河邊找鬼强品。 笑死膘侮,一個(gè)胖子當(dāng)著我的面吹牛屈糊,可吹牛的內(nèi)容都是我干的的榛。 我是一名探鬼主播,決...
    沈念sama閱讀 39,107評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼逻锐,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼夫晌!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起昧诱,我...
    開封第一講書人閱讀 37,845評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤晓淀,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后盏档,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體凶掰,經(jīng)...
    沈念sama閱讀 44,299評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,612評(píng)論 2 327
  • 正文 我和宋清朗相戀三年蜈亩,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了懦窘。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,747評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡稚配,死狀恐怖畅涂,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情道川,我是刑警寧澤午衰,帶...
    沈念sama閱讀 34,441評(píng)論 4 333
  • 正文 年R本政府宣布立宜,位于F島的核電站,受9級(jí)特大地震影響臊岸,放射性物質(zhì)發(fā)生泄漏橙数。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,072評(píng)論 3 317
  • 文/蒙蒙 一帅戒、第九天 我趴在偏房一處隱蔽的房頂上張望商模。 院中可真熱鬧,春花似錦蜘澜、人聲如沸施流。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,828評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)瞪醋。三九已至,卻和暖如春装诡,著一層夾襖步出監(jiān)牢的瞬間银受,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,069評(píng)論 1 267
  • 我被黑心中介騙來泰國(guó)打工鸦采, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留宾巍,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,545評(píng)論 2 362
  • 正文 我出身青樓渔伯,卻偏偏與公主長(zhǎng)得像顶霞,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子锣吼,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,658評(píng)論 2 350