pinia源碼解讀--實現(xiàn)概覽

\bullet 前言

????之前已經(jīng)通過讀文檔,寫demo乌询,知道了pinia怎么用背蟆,今天,來研究下pinia是怎么實現(xiàn)的

\bullet 程序入口

? ? 通過script中的build命令找到rollup配置文件

? ? 從打包配置可以看出其入口為src下的index

\bullet 向vue注冊(初始化)

? ? 示例代碼

? ? 通過vue的插件機制劣砍,允許向整個應(yīng)用程序注冊全局共享的功能惧蛹,寫法一般固定為對象內(nèi)含install方法,由于pinia同時支持vue2和vue3刑枝,在入口處其暴漏了PiniaVuePlugin和createPinia來分別實現(xiàn)插件注冊

? ??\ast PiniaVuePlugin

? ? ? ? 該函數(shù)利用mixins api向組件混入了beforeCreate周期鉤子香嗓,由于vue在組件實力化過程中會先讀取全局的mixins并會經(jīng)過一次配置合并過程,其中對生命周期的合并策略是數(shù)組的push装畅,故每一個組件實例初始化過程中都會callhook到beforeCreate

? ? ? ? 如下框紅所示靠娱,每一個組件實例中都將通過this訪問到pinia實例

? ??\ast createPinia

? ? ? ? 與vue2不同的是,vue3中通過provide+inject的方式向子孫組件注入

\bullet 定義掠兄、使用子模塊store? ??

? ??示例代碼

? ? 調(diào)用createPinia時像云,會向全局創(chuàng)建一個空對象作為根store,在組件使用時則對外提供了defineStore來定義組件的store蚂夕,這實際是在向根store做“add”操作

? ? 示例代碼

? ? 執(zhí)行定義函數(shù)調(diào)用后返回的useStore方法迅诬,會首先獲取到根store,接著將定義的本模塊的store設(shè)置到根store上并返回

\bullet store的創(chuàng)建過程

? ??示例代碼

? ? ? ? 承接上例

? ? 不管是option api形式還是setup形式婿牍,最終走的都是createSetupStore侈贷,在源碼層面對option形式做了次轉(zhuǎn)換

而store的創(chuàng)建過程其實分為兩部分:解析并掛載定義的store、為store裝飾api

? ??\ast 解析與掛載流程

? ??????\ast 裝飾api

? ? ? ? ? ? 這個比較簡單牍汹,就是將內(nèi)部的函數(shù)掛載到對象上并return出去即可

\bullet api相關(guān)

? ??\ast $reset

? ? ? ? 該api是$patch的語法糖铐维,只不過傳遞的參數(shù)是初始的state函數(shù)的執(zhí)行結(jié)果

? ??\ast $patch

? ? ? ? patch就是一次遞歸對value覆蓋的過程

? ??\ast $subscribe

? ? ? ? 有點類似觀察者柬泽,當(dāng)調(diào)用subscribe時,會將當(dāng)前的狀態(tài)信息保存到subscriptions

? ? ????此時嫁蛇,只需要在調(diào)用修改store相關(guān)的api時锨并,拿到subscriptions的數(shù)組依次run一遍即可

\bullet 插件機制

????通過pinia.use向pinia實例的_p屬性做緩存

? ? 接著,在創(chuàng)建store時將store傳遞給插件并執(zhí)行睬棚,如下extender即調(diào)用插件的初始化邏輯


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末第煮,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子抑党,更是在濱河造成了極大的恐慌包警,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,204評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件底靠,死亡現(xiàn)場離奇詭異害晦,居然都是意外死亡,警方通過查閱死者的電腦和手機暑中,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評論 3 395
  • 文/潘曉璐 我一進店門壹瘟,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人鳄逾,你說我怎么就攤上這事稻轨。” “怎么了雕凹?”我有些...
    開封第一講書人閱讀 164,548評論 0 354
  • 文/不壞的土叔 我叫張陵殴俱,是天一觀的道長。 經(jīng)常有香客問我枚抵,道長线欲,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,657評論 1 293
  • 正文 為了忘掉前任俄精,我火速辦了婚禮询筏,結(jié)果婚禮上榕堰,老公的妹妹穿的比我還像新娘竖慧。我一直安慰自己,他們只是感情好逆屡,可當(dāng)我...
    茶點故事閱讀 67,689評論 6 392
  • 文/花漫 我一把揭開白布圾旨。 她就那樣靜靜地躺著,像睡著了一般魏蔗。 火紅的嫁衣襯著肌膚如雪砍的。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,554評論 1 305
  • 那天莺治,我揣著相機與錄音廓鞠,去河邊找鬼帚稠。 笑死,一個胖子當(dāng)著我的面吹牛床佳,可吹牛的內(nèi)容都是我干的滋早。 我是一名探鬼主播,決...
    沈念sama閱讀 40,302評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼砌们,長吁一口氣:“原來是場噩夢啊……” “哼杆麸!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起浪感,我...
    開封第一講書人閱讀 39,216評論 0 276
  • 序言:老撾萬榮一對情侶失蹤昔头,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后影兽,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體揭斧,經(jīng)...
    沈念sama閱讀 45,661評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,851評論 3 336
  • 正文 我和宋清朗相戀三年峻堰,在試婚紗的時候發(fā)現(xiàn)自己被綠了未蝌。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,977評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡茧妒,死狀恐怖萧吠,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情桐筏,我是刑警寧澤纸型,帶...
    沈念sama閱讀 35,697評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站梅忌,受9級特大地震影響狰腌,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜牧氮,卻給世界環(huán)境...
    茶點故事閱讀 41,306評論 3 330
  • 文/蒙蒙 一琼腔、第九天 我趴在偏房一處隱蔽的房頂上張望踱葛。 院中可真熱鬧丹莲,春花似錦、人聲如沸尸诽。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,898評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽性含。三九已至洲赵,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背叠萍。 一陣腳步聲響...
    開封第一講書人閱讀 33,019評論 1 270
  • 我被黑心中介騙來泰國打工芝发, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人苛谷。 一個月前我還...
    沈念sama閱讀 48,138評論 3 370
  • 正文 我出身青樓后德,卻偏偏與公主長得像,于是被迫代替她去往敵國和親抄腔。 傳聞我的和親對象是個殘疾皇子瓢湃,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,927評論 2 355

推薦閱讀更多精彩內(nèi)容