您好,登錄后才能下訂單哦!
這篇文章主要講解了vue3默認把所有onSomething當作v-on事件綁定的原因,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。
最近在重新看vue3的rfcs,發現一個細節,原話如下:
props that start with on are handled as v-on bindings, with everything after on being converted to all-lowercase as the event name (more on this below)
也就是說,以后如果你在傳遞props的時候,以 on 開頭的props,如果在組件上沒有做props的聲明,那么會被當作事件綁定到組件的根節點上。
究其原因,我大致概括了兩點:
為此,我開了一個issue來討論這個問題,issue地址 。我關心的主要有兩點:
先講第一點
vue3中可以直接通過 function() {} 來聲明函數組件了,這是一個便利性的非常大的提升。在以前,你要聲明組件,你必須要:
{ functinal: true, props: {}, render() {} }
這最大的提升來自不需要聲明props,為什么說這是提升,因為這讓我們開發HOC變得更方便了。現在我們可以通過 ...rest 的方式把HOC不關心的props直接向下傳遞了。
但是現在因為這個默認限制,我們不得不在HOC中聲明所有可能的他要擴展的組件以 on 開頭的props。舉個例子,我們有如下組件:
{ props: { name: String, onChange: Function } }
而我們的HOC的功能是在 name 前面加上 prefix ,對于這個HOC我們需要關心的只是 name 和他自己的props: prefix 。所以他的聲明應該如下:
{ props: { name: String, prefix: String } }
然后在render中他可以這么做:
{ render() { const {name, prefix, ...rest} = props return <WrapperedComponent name={`${prefix}-${name}`} {...rest} /> } }
也就是對于HOC來說,他是不需要關心他擴展的組件其他的props的,但是在這種情況下,如果我們不在HOC中聲明,那么在使用的時候傳入的 onChange 會自動綁定到root節點,而不是作為props傳遞下去。
第二點:令人困惑的使用
舉個例子,如果我有一個組件:
{ props: { onChange: Function }, methods: { handleInput() { // do someting // 并且根據情況觸發`onChange` } }, render() { return <input onInput={this.handleInput} /> } }
很顯然我是想要封裝 input 的變化,在滿足某些條件的時候才對外拋出新的value。但是如果這個時候有人就是不看文檔,直接傳遞了 onInput ,那么這時候 input 事件會直接綁定到節點上,那么這也是可以觸發的。
如果我們的測試用例太少或者不仔細,很可能反應不過來他們的區別。這顯然是作為組件開發者的我們不希望出現的,但我們又無法限制這種行為。
總結
不得不說,我在考慮這兩個問題的時候是有一定的 React思維 在里面的。因為個人來說我是比較喜歡React的API設計的,非常的簡潔,其對于組件的使用也更趨于極致,就是一切皆組件(連 redirect 這樣的行為都定義成了組件)。
而vue是一直在跟隨react的,相信這點大家也不會否認。vue3更新的hooks(Composition)API,Suspense等明顯是借鑒的React的概念。
但同時我又是很看好vue3的,我一直覺得vue2這樣的API設計以及 .vue 文件的開發模式都是為了吸引中低級用戶而準備的,甚至舍棄了一些高級API特性(比如HOC在vue中就很難實現,并且普及率相當低)。
而vue3的hooks API以及其對JSX的更好支持,還有更純粹的 functional component ,讓我一度看到了vue在工程方面更激進的變化。
但是 v-on 的默認行為,卻又是一次那么明顯的 替用戶做決定 的行為。其實要解決這個問題很簡單,可以完全不考慮 v-on ,把所有傳遞的參數作為props,如果組件開發者真的要在根節點上綁定事件,他可以實現的時候綁定,我們不應該在使用組件的場景下需要考慮在組件內部的節點上做一些事情,這樣做的副作用實在太大了。
看完上述內容,是不是對vue3默認把所有onSomething當作v-on事件綁定的原因有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。