詳解Vue3 Composition API中的提取和重用邏輯
Vue3 Composition API可以在大型項(xiàng)目中更好地組織代碼。然兒,隨著使用幾種不同的選項(xiàng)屬性切換到單一的setup 方法,許多開(kāi)發(fā)人員面臨的問(wèn)題是……
這會(huì)不會(huì)更混亂,因?yàn)橐磺卸荚谝粋€(gè)方法中
乍一看可能很容易,但是實(shí)際上只需要花一點(diǎn)點(diǎn)時(shí)間來(lái)編寫可重用的模塊化代碼。
讓我們來(lái)看看如何做到這一點(diǎn)。
問(wèn)題
Vue.js 2.x 的 Options API 是一種非常直觀的分隔代碼的方法
export default { data () { return { articles: [], searchParameters: [] } }, mounted () { this.articles = ArticlesAPI.loadArticles() }, methods: { searchArticles (id) { return this.articles.filter(() => { // 一些搜索代碼 }) } } }
問(wèn)題是,如果一個(gè)組件中有數(shù)百行代碼,那么就必須在多個(gè)部分data、methods、computed等中為單個(gè)特性(例如搜索)添加代碼。
這意味著僅一項(xiàng)功能的代碼可能會(huì)分散分布在數(shù)百行中,并分布在幾個(gè)不同的位置,從而使其難以閱讀或調(diào)試。圖片描述
這只是Vue Composition API RFC中的一個(gè)示例,展示了現(xiàn)在如何按功能組織代碼。
現(xiàn)在,這是使用新的Composition API的等效代碼。
import { ref, onMounted } from 'vue' export default { setup () { const articles = ref([]) const searchParameters = ref([]) onMounted(() => { this.articles = ArticlesAPI.loadArticles() }) const searchArticles = (id) => { return articles.filter(() => { // 一些搜索代碼 }) } return { articles, searchParameters, searchArticles } } }
現(xiàn)在,為了解決前面關(guān)于組織的問(wèn)題,我們來(lái)看看一個(gè)提取邏輯的好方法。
提取邏輯
我們的最終目標(biāo)是將每個(gè)功能提取到自己的方法中。這樣一來(lái),如果我們想調(diào)試它,所有的代碼都在一個(gè)地方。
這非常簡(jiǎn)單,但是最后我們必須記住,如果我們希望能夠在模板中訪問(wèn)數(shù)據(jù),則仍然必須使用我們的 setup 方法來(lái)返回?cái)?shù)據(jù)。
我們來(lái)創(chuàng)建新方法 useSearchArticles 并讓它返回我們?cè)?setup 方法中返回的所有東西。
const useSearchArticles = () => { const articles = ref([]) const searchParameters = ref([]) onMounted(() => { this.articles = ArticlesAPI.loadArticles() }) const searchArticles = (id) => { return articles.filter(() => { // 一些搜索代碼 }) } return { articles, searchParameters, searchArticles } }
現(xiàn)在,在我們的 setup 方法中,我們可以通過(guò)調(diào)用我們的方法來(lái)訪問(wèn)屬性。而且,當(dāng)然,我們還必須記住從設(shè) setup 法中返回它們。
export default { setup () { const { articles, searchParameters, searchArticles } = useSearchArticles() return { articles, searchParameters, searchArticles } } }
在提取的邏輯中訪問(wèn)組件屬性
Composition API 中的另一個(gè)新變化是 this 引用的變化,這一變化意味著我們不能再以相同的方式使用 prop、attributes 或 events。
簡(jiǎn)而言之,我們將必須使用 setup 方法的兩個(gè)參數(shù)來(lái)訪問(wèn) props,attribute,slot 或 emit 方法。如果我們只使用 setup 方法,一個(gè)快速的虛擬組件可能是這樣的。
export default { setup (props, context) { onMounted(() => { console.log(props) context.emit('event', 'payload') }) } }
但是現(xiàn)在我們要提取我們的邏輯,我們要把我們的邏輯包裝器方法也接受參數(shù)。通過(guò)這種方式,我們可以從 setup 方法傳遞我們的 props 和 context 屬性,邏輯代碼可以訪問(wèn)它們。
const checkProps = (props, context) => { onMounted(() => { console.log(props) context.emit('event', 'payload') }) } export default { setup (props, context) { checkProps(props, context) } }
重用邏輯
最后,如果我們要編寫一些邏輯,希望能夠在多個(gè)組件中使用,則可以將邏輯提取到其自己的文件中,并將其導(dǎo)入到我們的組件中。
然后,我們可以像之前一樣調(diào)用該方法。假設(shè)我們將我們的 useSearchArticles 方法移至名為 use-search-articles-logic.js 的文件中,如下所示
import { ref, onMounted } from 'vue' export function useSearchArticles () { const articles = ref([]) const searchParameters = ref([]) onMounted(() => { this.articles = ArticlesAPI.loadArticles() }) const searchArticles = (id) => { return articles.filter(() => { // 一些搜索代碼 }) } return { articles, searchParameters, searchArticles } }
使用這個(gè)新文件,我們的原始組件將看起來(lái)像這樣
import { useSearchArticles } from './logic/use-search-articles-logic' export default { setup (props,) { const { articles, searchParameters, searchArticles } = useSearchArticles() return { articles, searchParameters, searchArticles } } }
最后
希望本文能幫助你更好地了解 Composition API 將如何改變我們的編碼方式。
但是,與往常一樣,項(xiàng)目的組織取決于開(kāi)發(fā)人員設(shè)計(jì)出色的組件代碼并創(chuàng)建可重用邏輯的意愿。
請(qǐng)記住,我們的目標(biāo)是提高可讀性,而在Vue中,Composition API 是實(shí)現(xiàn)這一點(diǎn)的好方法。
到此這篇關(guān)于詳解Vue3 Composition API中的提取和重用邏輯的文章就介紹到這了,更多相關(guān)Vue3 Composition提取和重用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用vue.js2.0 + ElementUI開(kāi)發(fā)后臺(tái)管理系統(tǒng)詳細(xì)教程(二)
這篇文章主要介紹了使用vue.js2.0 + ElementUI開(kāi)發(fā)后臺(tái)管理系統(tǒng)詳細(xì)教程(二),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧2017-01-01關(guān)于ElementPlus中的表單驗(yàn)證規(guī)則詳解
這篇文章主要介紹了關(guān)于ElementPlus中的表單驗(yàn)證,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-06-06nuxt 實(shí)現(xiàn)在其它js文件中使用store的方式
這篇文章主要介紹了nuxt 實(shí)現(xiàn)在其它js文件中使用store的方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11vue實(shí)現(xiàn)下拉框篩選表格數(shù)據(jù)
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)下拉框篩選表格數(shù)據(jù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-09-09解決vue-router路由攔截造成死循環(huán)問(wèn)題
這篇文章主要介紹了解決vue-router路由攔截造成死循環(huán)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-08-08vue實(shí)現(xiàn)循環(huán)滾動(dòng)圖片
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)循環(huán)滾動(dòng)圖片,多圖片輪播,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07