亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue函數(shù)式組件專篇深入分析

 更新時間:2023年01月05日 15:00:06   作者:loyd3  
Vue提供了一種稱為函數(shù)式組件的組件類型,用來定義那些沒有響應(yīng)數(shù)據(jù),也不需要有任何生命周期的場景,它只接受一些props來顯示組件,下面這篇文章主要給大家介紹了關(guān)于Vue高級組件之函數(shù)式組件的使用場景與源碼分析的相關(guān)資料,需要的朋友可以參考下

函數(shù)式組件的實現(xiàn)相對容易。一個函數(shù)式組件本質(zhì)上就是一個普通函數(shù),該函數(shù)的返回值是虛擬DOM。

在用戶接口層面,一個函數(shù)式組件就是一個返回虛擬DOM的函數(shù),如下面的代碼所示:

function MyFuncComp(props){
	return {type:'h1',children: porps.title}
}

函數(shù)式組件沒有自身狀態(tài),但仍然可以接收由外部傳入的props。為了給函數(shù)式組件定義props,需要在組件函數(shù)上添加靜態(tài)的props屬性,如下面代碼所示:

function MyFuncComp(props){
	return {type:'h1',children:props.title}
}
// 定義props
MyFuncComp.props = {
	title: String
}

在有狀態(tài)組件的基礎(chǔ)上,實現(xiàn)函數(shù)式組件將變得非常簡單,因為掛載組件的邏輯可以復用mountComponent函數(shù),為此,需要在patch函數(shù)內(nèi)支持函數(shù)類型的vnode.type,如下面patch函數(shù)的代碼所示:

function patch(n1,n2,container, anchor){
	if(n1 && n1.type !== n2.type){
		unmount(n1)
		n1 = null
	}
 	const {type} = n2
	if(typeof type === 'string'){
		// 省略部分代碼
	}else if(type === Text) {
		// 省略部分代碼
	}else if(type === Fragment) {
		// 省略部分代碼
	}else if(type === 'object' || typeof type === 'function') {
		// component
		if(!n1){
			mountComponent(n2,container,anchor)
		}else{
			patchComponent(n1,n2,anchor)
		}
	}
}

在patch函數(shù)內(nèi)部,通過檢測vnode.type的類型來判斷組件的類型

  • 如果vnode.type是一個對象,則它是一個有狀態(tài)組件,并且vnode.type是組件選項對象;
  • 如果vnode.type是一個函數(shù),則它是一個函數(shù)式組件

下面是修改后的mountComponent函數(shù),其支持掛載函數(shù)式組件:

function mountComponent(vnode,container,anchor){
	// 檢查是否是函數(shù)式組件
	const isFunctional = typeof vnode.type === 'function'
	let componentOptions = vnode.type
	if(isFunctional){
		// 如果是函數(shù)式組件,則將vnode.type作為渲染函數(shù),將vnode.type.props作為props選項定義即可
		componentOptions = {
			render:vnode.type,
			props: vnode.type.props
		}
	}
	// 省略部分代碼
}

實現(xiàn)對函數(shù)式組件的兼容非常簡單。首先,在mountComponent函數(shù)內(nèi)檢查組件的類型,如果是函數(shù)式組件,則直接將組件函數(shù)作為組件選項對象的render選項,并將組件函數(shù)的靜態(tài)props屬性作為組件的props選項即可。

當然,出于更加嚴謹?shù)目紤],我們需要通過isFunctional變量實現(xiàn)選擇性地執(zhí)行初始化邏輯,

到此這篇關(guān)于Vue函數(shù)式組件專篇深入分析的文章就介紹到這了,更多相關(guān)Vue函數(shù)式組件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue實現(xiàn)點擊翻轉(zhuǎn)效果

    vue實現(xiàn)點擊翻轉(zhuǎn)效果

    這篇文章主要為大家詳細介紹了vue實現(xiàn)點擊翻轉(zhuǎn)效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • TypeError:res.forEach?is?not?a?function報錯解決辦法

    TypeError:res.forEach?is?not?a?function報錯解決辦法

    這篇文章主要給大家介紹了關(guān)于TypeError:res.forEach?is?not?a?function報錯的解決辦法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2023-07-07
  • vue.js 初體驗之Chrome 插件開發(fā)實錄

    vue.js 初體驗之Chrome 插件開發(fā)實錄

    這篇文章主要介紹了vue.js 初體驗之Chrome 插件開發(fā)實錄 ,需要的朋友可以參考下
    2017-05-05
  • vue混入mixin流程與優(yōu)缺點詳解

    vue混入mixin流程與優(yōu)缺點詳解

    混入(mixin)提供了一種非常靈活的方式,來分發(fā)vue組件中的可復用功能。一個混入對象可以包含任意組件選項。當組件使用混入對象時,所有混入對象的選項將被“混合”進入該組件本身的選項
    2022-09-09
  • 詳解vue-cli中模擬數(shù)據(jù)的兩種方法

    詳解vue-cli中模擬數(shù)據(jù)的兩種方法

    這篇文章主要介紹了vue-cli中模擬數(shù)據(jù)的兩種方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-07-07
  • VUE中鼠標滾輪使div左右滾動的方法詳解

    VUE中鼠標滾輪使div左右滾動的方法詳解

    這篇文章主要給大家介紹了關(guān)于VUE中鼠標滾輪使div左右滾動的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • 使用Vue實現(xiàn)移動端左滑刪除效果附源碼

    使用Vue實現(xiàn)移動端左滑刪除效果附源碼

    這篇文章主要介紹了使用Vue實現(xiàn)移動端左滑刪除效果,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-05-05
  • vue+render+jsx實現(xiàn)可編輯動態(tài)多級表頭table的實例代碼

    vue+render+jsx實現(xiàn)可編輯動態(tài)多級表頭table的實例代碼

    這篇文章主要介紹了vue+render+jsx實現(xiàn)可編輯動態(tài)多級表頭table的實例代碼,本文通過實例代碼給大家介紹的非常詳細,對大家的工作或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • Vue中的驗證登錄狀態(tài)的實現(xiàn)方法

    Vue中的驗證登錄狀態(tài)的實現(xiàn)方法

    這篇文章主要介紹了Vue中的驗證登錄狀態(tài)的實現(xiàn)方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-03-03
  • 詳解Vue-cli 創(chuàng)建的項目如何跨域請求

    詳解Vue-cli 創(chuàng)建的項目如何跨域請求

    本篇文章主要介紹了詳解Vue-cli 創(chuàng)建的項目如何跨域請求 ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05

最新評論