鍍金池/ 問答/Linux  HTML/ 小程序mpvue中input和textarea使用v-model綁定時,當(dāng)刪除或

小程序mpvue中input和textarea使用v-model綁定時,當(dāng)刪除或改變數(shù)據(jù)時,光標(biāo)自動跑到最后

1.在mpvue小程序中,當(dāng)我在textarea標(biāo)簽中,使用v-model綁定數(shù)據(jù)時,當(dāng)要修改里面的數(shù)據(jù)時(比如刪除一段話中間的幾個字),當(dāng)我將光標(biāo)移動到要刪除的位置,第一次點擊刪除時,光標(biāo)會自動回到段落的尾部, input標(biāo)簽也是這樣的問題。
2.在使用v-model.lazy的時候,這個問題雖然解決了,但是,當(dāng)我填完表單,點擊提交的時候,數(shù)據(jù)并沒有傳給后臺,看了下mpvue文檔,v-model.lazy雖然在vue中屬于change事件,但是mpvue中,會將change事件自動轉(zhuǎn)換成blur事件,所以,只有輸入框表單失去焦點時,才會綁定數(shù)據(jù),而當(dāng)沒有失去焦點時,直接點擊提交按鈕,數(shù)據(jù)并沒有綁定,所以沒有提交到后臺。

終上所述:誰能給一個比較好的解決辦法,既可以讓光標(biāo)正常,也可以能立刻綁定傳到后臺?

目前的解決方案: 是在點擊提交按鈕時,給一個提示框,但是客戶不滿意,需要非阻塞提交,無感提交,直接提交到后臺。麻煩大家給一個好一點的方案,謝謝!

使用的設(shè)備是:iPhone6s 系統(tǒng)是IOS11.3,微信版本是6.6.6

回答
編輯回答
笨小蛋

你給提交按鈕添加一個邏輯,手動blur輸入框?

2017年12月12日 11:54
編輯回答
冷咖啡

mpvue文檔原鏈第3條里提到
合理使用雙向綁定建議使用 v-model.lazy 綁定方式以優(yōu)化性能,此外 v-model 在老基礎(chǔ)庫下輸入框輸入時可能存在光標(biāo)重設(shè)的問題。

所以使用v-model.lazy就可以解決你說的光標(biāo)不正常的情況。

vue文檔里的解釋:
.lazy
在默認(rèn)情況下,v-model 在每次 input 事件觸發(fā)后將輸入框的值與數(shù)據(jù)進行同步 (除了上述輸入法組合文字時)。你可以添加 lazy 修飾符,從而轉(zhuǎn)變?yōu)槭褂?change 事件進行同步

2017年3月13日 04:05
編輯回答
尐懶貓

目前解決了,使用lazy修飾符有個缺點,就是lazy修飾符會被Vue編譯成change事件,而mpvue會把change事件轉(zhuǎn)換成blur事件,也就是當(dāng)光標(biāo)移動開時,才開始綁定數(shù)據(jù)值。所以這樣會導(dǎo)致,如果用戶輸入了最后一個輸入框(使用lazy修飾符的),沒有將光標(biāo)移開,而是直接點擊提交,則最后一個提交會被忽略,看了下底層源碼,是由于blur事件觸發(fā)在點擊提交之后,比較慢,所以導(dǎo)致這樣的原因,目前的解決方案是:
1、使用lazy修飾符,即v-model.lazy進行數(shù)據(jù)綁定。
2、在進行數(shù)據(jù)傳輸或調(diào)用接口,或者提交的時候,做一個延時,使用setTimeout大概延時個100毫秒
優(yōu)點:這樣的話,數(shù)據(jù)綁定的時候,光標(biāo)不會閃爍,同時,在刪除時,光標(biāo)不會自動回到最后,也解決了提交blur時間太慢的問題。
缺點:就算是使用了v-model.lazy,當(dāng)遇到定時器進行實時修改數(shù)據(jù)時,會出現(xiàn)一定的bug

2017年3月19日 08:45