欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue中input type=file上傳后@change事件無效的解決方案

 更新時間:2023年05月25日 10:27:40   作者:高效編程  
這篇文章主要介紹了vue中input type=file上傳后@change事件無效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

input type=file上傳后@change事件無效的解決

為什么@change事件會無效?

綁定事件無效的問題,不僅僅是Vue中才會出現(xiàn)的,寫原生js時同樣是上傳完文件后將無法觸發(fā)事件,簡單查閱資料,似乎與上傳的DOM組件相關(guān),因項目緊急也沒有深究。

怎么解決事件不觸發(fā)的問題?

網(wǎng)上大多文章說是要移除<input type='file' id='demo'\>再通過JS動態(tài)添加,這樣確實可以解決問題,vue 中也有很多文章說 通過 v-if ,我試過之后發(fā)現(xiàn)v-if也不生效了

借助jQuery重新添加事件,可以解決

我們在上傳文件處理完成后,重新添加事件

$("#demo").on("change",function);

將input 選擇的文件置空(初始化)

document.getElementById("demo").value='';

input的type=file觸發(fā)的相關(guān)事件

今天突然用到input相關(guān)的事件,突然發(fā)現(xiàn)自己還沒有總結(jié)過input相關(guān)事件的運行原理。而且我還竟然翻api去了解了,所以,為了記恨自己,就寫了相關(guān)與input相關(guān)的事件運行的過程。

添加了一些相關(guān)的方法測試了一下。這一節(jié)首先介紹一個input的type=file的運行流程。

我們書寫了mousedown,mouseup,click,input,change,focus,blur綁定到了input上面,模擬點擊選擇了一個文件,觸發(fā)事件的流程是下面這樣的:

  • (1)mousedown
  • (2)focus
  • (3)mouseup
  • (4)click
  • (5)blur
  • (6)focus
  • (7)change

首先觸發(fā)了鼠標(biāo)按下事件,然后就是焦點到了input上面,然后鼠標(biāo)抬起,觸發(fā)click點擊事件,失去焦點以后彈出了文件選擇框,選中文件以后觸發(fā)焦點,最后觸發(fā)的change事件。

如果你沒有選擇文件的話,直接點擊取消的話,就不會觸發(fā)change事件。

所以說,如果要監(jiān)聽input 的type=file的內(nèi)容變更事件的話,最好直接用change事件去監(jiān)聽。

附上案例代碼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<input type="file" id="input">
</body>
<script>
    document.getElementById("input").addEventListener("focus",function () {
        console.log("focus");
    });
    document.getElementById("input").addEventListener("mousedown",function () {
        console.log("mousedown");
    });
    document.getElementById("input").addEventListener("mouseup",function () {
        console.log("mouseup");
    });
    document.getElementById("input").addEventListener("input",function () {
        console.log("input");
    });
    document.getElementById("input").addEventListener("change",function () {
        console.log("change");
    });
    document.getElementById("input").addEventListener("blur",function () {
        console.log("blur");
    });
    document.getElementById("input").addEventListener("click",function () {
        console.log("click");
    });
</script>
</html>

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • VueJS如何引入css或者less文件的一些坑

    VueJS如何引入css或者less文件的一些坑

    本篇文章主要介紹了VueJS如何引入css或者less文件的一些坑,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • Vue常用指令V-model用法

    Vue常用指令V-model用法

    本篇文章主要介紹了Vue常用指令_V-model用法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • Vue.js axios響應(yīng)攔截如何獲取返回狀態(tài)碼

    Vue.js axios響應(yīng)攔截如何獲取返回狀態(tài)碼

    這篇文章主要介紹了Vue.js axios響應(yīng)攔截如何獲取返回狀態(tài)碼問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • vxe-table?實現(xiàn)?excel?選擇一個單元格拖拽自動復(fù)制新的單元格(示例代碼)

    vxe-table?實現(xiàn)?excel?選擇一個單元格拖拽自動復(fù)制新的單元格(示例代碼)

    vxe-table是一款強大的表格組件,支持Excel風(fēng)格的操作,通過鼠標(biāo)右下角的擴展按鈕,用戶可以拖拽選擇單元格并自動復(fù)制內(nèi)容到擴展區(qū)域的所有單元格中,本文通過示例代碼給大家介紹的非常詳細,感興趣的朋友一起看看吧
    2025-01-01
  • vue大型項目之分模塊運行/打包的實現(xiàn)

    vue大型項目之分模塊運行/打包的實現(xiàn)

    這篇文章主要介紹了vue大型項目之分模塊運行/打包的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • vue el-table字段點擊出現(xiàn)el-input輸入框,失焦保存方式

    vue el-table字段點擊出現(xiàn)el-input輸入框,失焦保存方式

    這篇文章主要介紹了vue el-table字段點擊出現(xiàn)el-input輸入框,失焦保存方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-02-02
  • vue3插件json2ts的具體使用

    vue3插件json2ts的具體使用

    本文主要介紹了vue3插件json2ts的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • vue手機端input change時,無法執(zhí)行的問題及解決

    vue手機端input change時,無法執(zhí)行的問題及解決

    這篇文章主要介紹了vue手機端input change時,無法執(zhí)行的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Vue echarts 實現(xiàn)離線中國地圖的示例代碼(細化到省份)

    Vue echarts 實現(xiàn)離線中國地圖的示例代碼(細化到省份)

    這篇文章主要介紹了Vue echarts 實現(xiàn)離線中國地圖,細化到省份,本文通過示例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-09-09
  • 利用Vue.js+Node.js+MongoDB實現(xiàn)一個博客系統(tǒng)(附源碼)

    利用Vue.js+Node.js+MongoDB實現(xiàn)一個博客系統(tǒng)(附源碼)

    本文主要介紹了利用Vue.js+Node.js+MongoDB實現(xiàn)一個博客系統(tǒng),這個博客使用Vue做前端框架,Node+express做后端,數(shù)據(jù)庫使用的是MongoDB。實現(xiàn)了用戶注冊、用戶登錄、博客管理、文章編輯、標(biāo)簽分類等功能,需要的朋友可以參考學(xué)習(xí)。
    2017-04-04

最新評論