摘要:寫文章不容易,點個贊唄兄弟專注源碼分享,文章分為白話版和源碼版,白話版助于理解工作原理,源碼版助于了解內部詳情,讓我們一起學習吧研究基于版本如果你覺得排版難看,請點擊下面鏈接或者拉到下面關注公眾號也可以吧原理白話版插槽作為組件一個重要的部
寫文章不容易,點個贊唄兄弟
專注 Vue 源碼分享,文章分為白話版和 源碼版,白話版助于理解工作原理,源碼版助于了解內部詳情,讓我們一起學習吧
研究基于 Vue版本 【2.5.17】
如果你覺得排版難看,請點擊 下面鏈接 或者 拉到 下面關注公眾號也可以吧
【Vue原理】Slot - 白話版
插槽作為組件一個重要的部分,在項目中也是經常會用到的,起到自定義組件的作用。
插槽,按照處理方式,我覺得大概可以分為兩種,一種是普通插槽,一種是作用域插槽
普通插槽,就是不給名字的默認插槽和 具名插槽
作用域插槽,就是使用子作用域數據的插槽
接下來,我們簡單解釋一下插槽的處理流程,主要理解思想和流程
普通插槽下面以默認插槽來說,就是不給名字的插槽
父組件中使用組件 test,并且使用插槽
子組件 test 模板
1、父組件先解析,把 test 當做子元素處理,把 插槽當做 test 的子元素處理,生成這樣的節點
{ tag: "div", children: [{ tag: "test", children: ["插入slot 中"] }] }
插槽的節點就是上面的
["插入slot 中"]
2、子組件解析,slot 作為一個占位符,會被解析成一個函數
大概意思像 解析成下面
{ tag: "main", children: [ "我在子組件里面", _t("default") ] }
3、這個 _t 函數,傳入 "default " 參數并執行
因為這里不給名字,默認插槽,所以是default,如果給了名字,就傳入你的名字
這個函數的作用,是把第一步解析得到的插槽節點拿到,然后返回
那么子組件的節點就完整了,插槽也成功認了爹
{ tag: "main", children: ["我在子組件里面","插入slot 中"] }作用域插槽
父組件中使用 test 組件,test 組件使用作用域插槽
子組件 test 模板
子組件的數據
1、父組件先解析,把 test 當做子元素處理,把 插槽包裝成一個函數,保存給節點
大概意思是這樣,為了便于理解主要思想,實際操作要復雜很多
{ tag: "div", children: [{ tag: "test" scopeSlots:{ default(slotProps){ return ["插入slot 中" + slotProps] } } }] }
2、子組件解析,slot 作為一個占位符,會被解析成一個函數
{ tag: "main", children: [ "我在子組件里面", _t("default",{child:11}) ] }
這個 _t 函數,和普通插槽 的一樣,但是你可以看到,多傳了一個參數 { child:11 }
為什么多一個參數?因為這是作用域插槽啊,子組件要傳給插槽的數據啊
_t 函數執行的時候,得到兩個參數
1、插槽函數名字 default
2、需要的作用域數據 { child:11 }
_t 內部執行
1、根據傳入的名字("default"),拿到第一步解析插槽得到的函數(代號為A)
2、執行A,傳入參數 { child:11 }
function A(slotProps){ return ["插入slot 中" + slotProps] }
于是作用域插槽,就拿到了子組件傳過來的數據了
插槽函數執行,會返回解析后的插槽節點,_t 拿到這個節點,直接 return 出去
于是子組件插槽就完成替換 slot 占位符了,變成下面這樣
{ tag: "main", children: [ "我在子組件里面", _t("default",{child:11}) ] } 變成下面這樣 { tag: "main", children: [ "我在子組件里面", "插入slot 中 {child:11}" ] }
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/105264.html
摘要:寫文章不容易,點個贊唄兄弟專注源碼分享,文章分為白話版和源碼版,白話版助于理解工作原理,源碼版助于了解內部詳情,讓我們一起學習吧研究基于版本如果你覺得排版難看,請點擊下面鏈接或者拉到下面關注公眾號也可以吧原理白話版從模板上使用到掛載到頁面 寫文章不容易,點個贊唄兄弟專注 Vue 源碼分享,文章分為白話版和 源碼版,白話版助于理解工作原理,源碼版助于了解內部詳情,讓我們一起學習吧研究基于...
摘要:我們都知道分為普通和作用域,兩個內容都很多,所以分兩部分進行講述。今天講的是普通其實普通,表示默認和具名,只是他們的處理方式都差不多,就只是是否有自定義名字而已,所以,表示一種類型。 寫文章不容易,點個贊唄兄弟專注 Vue 源碼分享,文章分為白話版和 源碼版,白話版助于理解工作原理,源碼版助于了解內部詳情,讓我們一起學習吧研究基于 Vue版本 【2.5.17】 如果你覺得排版難看,請...
摘要:通過函數參數傳遞的形式,讓插槽的變量,在解析時,先訪問函數變量。那么這兩個有什么關系呢外殼節點保存著所有父組件里給這個子組件綁定的數據,比如,插槽等。 寫文章不容易,點個贊唄兄弟專注 Vue 源碼分享,文章分為白話版和 源碼版,白話版助于理解工作原理,源碼版助于了解內部詳情,讓我們一起學習吧研究基于 Vue版本 【2.5.17】 如果你覺得排版難看,請點擊 下面鏈接 或者 拉到 下面...
摘要:寫文章不容易,點個贊唄兄弟專注源碼分享,文章分為白話版和源碼版,白話版助于理解工作原理,源碼版助于了解內部詳情,讓我們一起學習吧研究基于版本如果你覺得排版難看,請點擊下面鏈接或者拉到下面關注公眾號也可以吧原理源碼版之節點數據拼接上一篇我們 寫文章不容易,點個贊唄兄弟 專注 Vue 源碼分享,文章分為白話版和 源碼版,白話版助于理解工作原理,源碼版助于了解內部詳情,讓我們一起學習吧研究...
摘要:還原的難度就在于變成模板了,因為其他的什么等是原封不動的哈哈,可是直接照抄最后鑒于本人能力有限,難免會有疏漏錯誤的地方,請大家多多包涵,如果有任何描述不當的地方,歡迎后臺聯系本人,有重謝 寫文章不容易,點個贊唄兄弟 專注 Vue 源碼分享,文章分為白話版和 源碼版,白話版助于理解工作原理,源碼版助于了解內部詳情,讓我們一起學習吧研究基于 Vue版本 【2.5.17】 如果你覺得排版...
閱讀 3560·2021-10-09 09:43
閱讀 6177·2021-09-07 10:15
閱讀 2757·2019-08-30 14:03
閱讀 3088·2019-08-29 11:01
閱讀 1724·2019-08-29 10:56
閱讀 1089·2019-08-28 17:52
閱讀 3508·2019-08-26 11:42
閱讀 2564·2019-08-26 10:33