為什麼 Vue3 外掛程式的工作方式與以往不同
在 Vue2 中,大多數外掛程式將屬性注入到 this 上。例如可以透過 this.$router 存取 Vue 路由器。
但是,setup() 方法不再包含對 this 的相同參考。進行這種更改的主要原因是增加了對 Typescript 的支援。
那麼在 Vue3 中該如何存取我們的外掛呢?可以用 provide 和 inject 來幫助我們在 Vue 程式中註入依賴項。 Provide/inject 用於依賴項注入,可讓我們在 Vue 程式的根目錄中提供插件,並且然後將其註入子元件中。
在 Composition API 中,只能在 setup() 方法期間呼叫這兩種方法。
什麼是 provide 和 inject
我們需要某種鍵來辨識依賴關係, Javascript 的 Symbol 可以複合這個要求。
然後 provide 方法會將我們的 Symbol 與某個值相關聯,而 inject 方法會用相同的 Symbol 檢索這個值。
下面是一個範例:
import { provide, inject } from 'vue' const LoggedInSymbol = Symbol() const ParentComponent = { setup() { provide(LoggedInSymbol, true) } } const DeepDescendent = { setup() { // 第二个可选参数是默认值(如果不存在) const isLoggedIn = inject(LoggedInSymbol, false) return { isLoggedIn } } }
Vue3 透過這個模式可以實現一些很實用的技巧。
可以在程式中全域提供相依性
如果我們想在全域作用域中提供一些東西,可以在宣告我們的 VUE 實例的時候使用 app.provide。然後可以用相同的方式進行注入。
main.jsimport { createApp } from 'vue' import App from './App.vue' const app = createApp(App) const ThemeSymbol = Symbol() app.provide(ThemeSymbol, 'dark') app.mount('#app')
可以用 ref 提供響應式資料
如果我們希望將響應式資料傳遞給子元件,這也非常方便。只需要用 ref() 傳遞我們方法的一個響應式的屬性。
// 生产者r (父组件) const LoggedInSymbol = Symbol() const loggedIn = ref('true') provide(LoggedInSymbol, loggedIn) // 消费者 (子组件) const theme = inject(LoggedInSymbol, ref('false'))
怎麼在插件中使用 provide 和 inject
實際上設計插件與我們剛才看到的簡單範例非常相似。
但是我們不想使用單一值,而是要使用組合函數。這是 Vue3 的一個巨大優勢 —— 能夠根據函數組織和提取程式碼。
由於我們的程式碼無論如何都應該用有組織的組合函數來寫,所以只需要建立這些 provide 和 inject 方法就能夠寫出一個外掛程式。
先簡單的看一下 Vue3 Composition API 文件中提供的外掛範例。
Plugin.jsconst StoreSymbol = Symbol() export function provideStore(store) { provide(StoreSymbol, store) } export function useStore() { const store = inject(StoreSymbol) if (!store) { // throw error, no store provided } return store }
在實際的元件中會這樣使用:
// 在组件根目录提供 store // const App = { setup() { provideStore(store) } } const Child = { setup() { const store = useStore() // use the store } }
根據上述程式碼,在某些根元件中,我們提供了插件,並向其傳遞了元件函數。然後無論想在哪裡使用都必須將其註入到我們的組件中。
元件永遠不必真正進行 provide/inject 調用,而只需調用插件公開的 provideStore/useStore 方法即可。
還能用舊的外掛嗎
簡單的來說是:能。如果多說一點,那就是取決於你自己的想法。
可以繼續使用 Options API,並且對 this 的引用方式與以前相同,並且所有舊插件的工作方式都不變。
但是遷移到 Vue3 並利用其所有功能覺得是值得的。
只要你想用 Vue2 的 Options API,你的外掛就可以正常運作。但是,許多維護良好的插件或程式庫都應該添加對 Vue3 的支援。
以上是Vue3插件中怎麼使用Provide和Inject的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Vue.js更易用且學習曲線較平緩,適合初學者;React學習曲線較陡峭,但靈活性強,適合有經驗的開發者。 1.Vue.js通過簡單的數據綁定和漸進式設計易於上手。 2.React需要理解虛擬DOM和JSX,但提供更高的靈活性和性能優勢。

Vue.js適合快速開發和小型項目,而React更適合大型和復雜的項目。 1.Vue.js簡單易學,適用於快速開發和小型項目。 2.React功能強大,適合大型和復雜的項目。 3.Vue.js的漸進式特性適合逐步引入功能。 4.React的組件化和虛擬DOM在處理複雜UI和數據密集型應用時表現出色。

Vue.js和React各有優缺點,選擇時需綜合考慮團隊技能、項目規模和性能需求。 1)Vue.js適合快速開發和小型項目,學習曲線低,但深層嵌套對象可能導致性能問題。 2)React適用於大型和復雜應用,生態系統豐富,但頻繁更新可能導致性能瓶頸。

Vue.js適合小型到中型項目,React適合大型項目和復雜應用場景。 1)Vue.js易於上手,適用於快速原型開發和小型應用。 2)React在處理複雜狀態管理和性能優化方面更有優勢,適合大型項目。

Vue.js和React各有優勢:Vue.js適用於小型應用和快速開發,React適合大型應用和復雜狀態管理。 1.Vue.js通過響應式系統實現自動更新,適用於小型應用。 2.React使用虛擬DOM和diff算法,適合大型和復雜應用。選擇框架時需考慮項目需求和團隊技術棧。

Vue.js和React各有優勢,選擇應基於項目需求和團隊技術棧。 1.Vue.js社區友好,提供豐富學習資源,生態系統包括VueRouter等官方工具,支持由官方團隊和社區提供。 2.React社區偏向企業應用,生態系統強大,支持由Facebook及其社區提供,更新頻繁。

Netflix使用React來提升用戶體驗。 1)React的組件化特性幫助Netflix將復雜UI拆分成可管理模塊。 2)虛擬DOM優化了UI更新,提高了性能。 3)結合Redux和GraphQL,Netflix高效管理應用狀態和數據流動。

Vue.js是前端框架,後端框架用於處理服務器端邏輯。 1)Vue.js專注於構建用戶界面,通過組件化和響應式數據綁定簡化開發。 2)後端框架如Express、Django處理HTTP請求、數據庫操作和業務邏輯,運行在服務器上。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Atom編輯器mac版下載
最受歡迎的的開源編輯器

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中