亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何解決vue項目中type=”file“ change事件只執行一次的問題

發布時間:2021-07-20 09:48:06 來源:億速云 閱讀:322 作者:小新 欄目:web開發

這篇文章將為大家詳細講解有關如何解決vue項目中type=”file“ change事件只執行一次的問題,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

問題描述

在最近的項目開發中遇到了這樣的一個問題,當我上傳了一個文件時,我將獲取到的文件名清空后,卻無法再次上傳相同的文件

<template>
 <div class="hello">
   <input type="button" value="上傳文件" name="" id="" @click="updata">
   <input type="file"  @change="getFile" id="input-file">
   <div v-if="fileName">
    <p>上傳的文件名:{{fileName}}</p>
    <button @click="delFile">清空文件</button>
   </div>
 </div>
</template>
<script>
import $ from 'n-zepto'
export default {
 name: 'HelloWorld',
 data () {
  return {
   fileName: ''
  }
 },
 methods:{
  updata(){ // 喚起change事件
   $('#input-file').click()
  },
  getFile(e){ // change事件
   this.doSomething()
  },
  doSomething(){ // do something
   this.fileName = e.target.files[0].name
  },
  delFile(){
   this.fileName=''
  }
 }
}
</script>

因為我只是將data中的屬性值清空而已,文件名沒有變當然會不出發change事件

解決辦法

目前網上有好多解決辦法,但基本上都無法在vue上使用,于是我想到了v-if

v-if 是“真正”的條件渲染,因為它會確保在切換過程中條件塊內的事件監聽器和子組件適當地被銷毀和重建。

于是在代碼中加入了一個小的開關,喚起change事件時就將他銷毀

事件結束時再將它重建,這樣問題就輕松的解決了

<template>
 <div class="hello">
   <input type="button" value="上傳文件" name="" id="" @click="updata">
   <input v-if="ishowFile" type="file"  @change="getFile" id="input-file">
   <div v-if="fileName">
    <p>上傳的文件名:{{fileName}}</p>
    <button @click="delFile">清空文件</button>
   </div>
 </div>
</template>

<script>
import $ from 'n-zepto'
export default {
 name: 'HelloWorld',
 data () {
  return {
   fileName: '',
   ishowFile: true,
  }
 },
 methods:{
  updata(){ // 喚起change事件
   $('#input-file').click()
   this.ishowFile = false // 銷毀
  },
  getFile(e){ // change事件
   this.doSomething()
   this.ishowFile = false // 重建
  },
  doSomething(){ // do something
   this.fileName = e.target.files[0].name
  },
  delFile(){
   this.fileName=''
  }
 }
}
</script>

關于“如何解決vue項目中type=”file“ change事件只執行一次的問題”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

林芝县| 四川省| 宝丰县| 扶风县| 铜梁县| 鸡西市| 上林县| 中阳县| 安陆市| 深水埗区| 普宁市| 宁强县| 金坛市| 怀宁县| 阳东县| 曲水县| 盐山县| 高清| 龙胜| 隆子县| 新龙县| 丽江市| 彝良县| 定远县| 伊金霍洛旗| 崇信县| 三台县| 吉林市| 墨竹工卡县| 陆川县| 普兰店市| 佛坪县| 尤溪县| 越西县| 乌拉特前旗| 太原市| 莱芜市| 西乡县| 沙田区| 密山市| 蛟河市|