[vue] 表單輸入格式化,中文輸入法異常

来源:https://www.cnblogs.com/-zyq-/archive/2018/05/29/9108143.html
-Advertisement-
Play Games

v-model 是 vue.js 提供的語法糖,根據不同的表單控制項監聽不同的事件,實現對錶單控制項的數據雙向綁定。 當控制項是 <input> 輸入框時,v-model 監聽其 input 事件。 如下所示,這兩種寫法有什麼區別嗎? 輸入中文格式化問題 表單輸入常見需求:對<input>控制項輸入的內容進 ...


v-model 是 vue.js 提供的語法糖,根據不同的表單控制項監聽不同的事件,實現對錶單控制項的數據雙向綁定。

當控制項是 <input> 輸入框時,v-model 監聽其 input 事件。

如下所示,這兩種寫法有什麼區別嗎?

<input :value="name" @input="name = $event.target.value">
<input v-model="name">

 

輸入中文格式化問題

表單輸入常見需求:對<input>控制項輸入的內容進行格式化,譬如:轉成大寫字母。如果輸入的值包含中文,格式化就會引起輸入法異常。

如下圖所示,也可以線上嘗試

 

如果使用 v-model 指令實現數據雙向綁定,就不會出現輸入法異常,如下圖所示,也可以線上嘗試

 

上面的問題,可以看出 v-model 不只是給變數賦值,那麼,它還做了些什麼呢?

 

v-model 源碼分析

本文參考的 vue.js 源代碼是 2.5.16

 

翻看 v-model 源碼,可以看到 v-model 關註的仍然是 input 事件

 

input 事件綁定的回調代碼處理,如下:

這裡可以看到,v-model 判斷了 composing 屬性,當輸入法組合沒有結束的時候,直接返回,並沒有賦值。

 

composing 屬性並不是標準 dom 元素屬性,那它是怎麼來的呢?

這裡可以看出,composing 屬性是 vue.js 添加到 dom 節點上的。

 

那麼,是什麼地方調用了這2個函數呢?可以看到,在插入dom節點時,vue.js 監聽了 compositionstart / compositionend 事件

compositionstart / compositionend 這2個 dom 事件,瀏覽器相容性問題可以查閱 MDN 說明:

 

源代碼中還發現,在是否刷新 dom 屬性值時,也用到了 composing 屬性:

這裡可以看出,在輸入法組合過程中,vue.js 變數值的更新亦不會同步到 dom元素的 value 屬性。

 

綜上所述:

  • v-model 實際上是監聽了 <input> 控制項的 input、compositionstart、compositionend 三個事件,在輸入法組合過程中就直接返回不賦值
  • v-model 指令設置了變數 composing,此標識還用於判斷是否更新 dom元素的 value 屬性

 

v-model 輸入中文觸發的事件

從上面源代碼分析可知,v-model 綁定 <input> 輸入中文時,實際觸發的事件如下:

compositionstart => 3個 input => compositionend 事件,這些都是 <input>控制項觸發的。最後一個 input 事件,是源代碼裡面看到的 onCompositionEnd 回調裡面 vue.js 觸發的。

1、compositionstart事件

修改dom對象的composing屬性為 true

2、3個input事件

由於dom對象的composing屬性為true,不會賦值,直接返回。

3、compositioinend事件

修改dom對象的composing屬性為 false

4、vue.js觸發的 input事件

由於dom對象的composing屬性為false,賦值,修改相應變數的值。

 

格式化問題原因分析

再次看下文章開頭的示例,如果使用 v-model 指令實現數據雙向綁定,就不會出現輸入法異常,如下圖所示,也可以線上嘗試

由前面的分析可知:

  • v-model 指令設置了變數 composing,雖然代碼在 format 函數里更改了 this.name 的值,但此時 composing 標識阻止了將 this.name 的值同步給 input 元素的 value 屬性
  • 如果你感興趣的話,可以修改 vue.js 的源代碼,將 shouldUpdateValue 函數里對 composing 屬性的判斷去掉,可以看到輸入法又跟之前一樣異常了

 

格式化問題 bugfix

再次看下文章開頭的示例,如果使用 :value, @input 實現數據雙向綁定,有兩個方案可以解決中文輸入異常的問題。

方案一:監聽 change 事件

等輸入結束失去焦點以後,再調用格式化方法,如下所示,也可以線上嘗試

 

方案二:監聽 input 事件,同時判斷輸入法組合過程

在輸入法組合過程中,不進行格式化,如下所示,也可以線上嘗試

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • MongoDB 3.6.5 2008R2Plus SSL (64 bit) Setup Wizard ended prematurely 在安裝 MongoDB 的時候,出現了 MongoDB 3.6.5 2008R2Plus SSL (64 bit) Setup Wizard ended prem ...
  • 本文將介紹如何分組數據,以便能彙總表內容的子集,這涉及兩個新SELECT語句子句,分別是 GROUP BY 子句和 HAVING 子句。 1.1 創建分組 分組是在SELECT語句的GROUP BY子句中建立的。 輸入: 輸出: vend_id | num_prods | 1001 | 3 1002 ...
  • Apple在Xcode4.2中推出用於iOS應用故事版概念。 標識:Identity(標識)檢查器最常用於為用戶界面元素或者控制器分配一個自定義類。 屬性:Attributes(屬性)檢查器在微調用戶界面元素的行為時頻繁使用。註意,並不是UI元素的所有屬性都可以在這裡配置,有一些只能通過代碼進行。 ...
  • 渲染性能 Android UI的工作分兩階段: 1.在UI線程Record View#draw 2.在RenderThread線程DrawFrame(RenderThread:使用GPU資源的線程) 第一階段隨著View的invalidated在draw(Canvas)中進行 第二階段native ...
  • 一、編譯時檢測 1. 判斷 SDK 是否是某個版本或更高版本 2.判斷當前需要支持的最低版本 ​ 這個巨集的取值也就是 這個值,也就是你的工程支持的最低系統版本。但是最少是 __IPHONE_2_0。 3.判斷最高可支持的系統版本 這個巨集的值等於當前 SDK 定義的最高版本,比如 \__IPHONE_ ...
  • 正則表達式規則 一、普通字元 字母、數字、漢字、下劃線、以及後邊章節中沒有特殊定義的標點符號,都是"普通字元"。表達式中的普通字元,在匹配一個字元串的時候,匹配與之相同的一個字元。 舉例: 表達式 "o",在匹配字元串 "haorooms" 時,匹配結果是:成功;匹配到的內容是:"o";匹配到的位置 ...
  • 本文主要講解javascript 的正則表達式中的分組匹配與前瞻匹配的,需要對正則的有基本認識,本人一直對兩種匹配模棱不清。所以在這裡總結一下,如有不對,還望大神指點。 1.分組匹配: 1.1捕獲性分組匹配 () 2.2非捕獲性分組匹配 (?:)2前瞻匹配: 2.1正向前瞻匹配: (?=表達式) 後 ...
  • 1.1 html概述和基本結構 html概述 HTML是 HyperText Mark-up Language 的首字母簡寫,意思是超文本標記語言,超文本指的是超鏈接,標記指的是標簽,是一種用來製作網頁的語言,這種語言由一個個的標簽組成,用這種語言製作的文件保存的是一個文本文件,文件的擴展名為htm ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...