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

vue中provide、inject的使用方法案例詳解

 更新時(shí)間:2024年02月05日 14:54:53   作者:還是大劍師蘭特  
本教程是介紹如何在vue中使用provide和inject,在 Vue 中,provide 和 inject 是用于實(shí)現(xiàn)祖先組件向后代組件傳遞數(shù)據(jù)的一種方式,對(duì)vue中provide、inject的使用方法感興趣的朋友一起看看吧

示例背景

本教程是介紹如何在vue中使用provide和inject。在 Vue 中,provide 和 inject 是用于實(shí)現(xiàn)祖先組件向后代組件傳遞數(shù)據(jù)的一種方式。 在這個(gè)示例中,祖組件通過(guò) provide 提供了 message 變量 和message2 變量 ,子組件通過(guò) inject 注入了 message 變量,孫組件通過(guò) inject 注入了 message2 變量。這樣,子組件和孫就可以訪問(wèn)到父組件提供的數(shù)據(jù)。

示例效果圖

示例源代碼

父組件代碼

/*
* @Author: 大劍師蘭特(xiaozhuanlan),還是大劍師蘭特(CSDN)
* @此源代碼版權(quán)歸大劍師蘭特所有,可供學(xué)習(xí)或商業(yè)項(xiàng)目中借鑒,未經(jīng)授權(quán),不得重復(fù)地發(fā)表到博客、論壇,問(wèn)答,git等公共空間或網(wǎng)站中。
* @Email: 2909222303@qq.com
* @weixin: gis-dajianshi
* @First published in CSDN
* @First published time: 2024-02-04
*/
<template>
	<div class="djs-box">
		<div class="topBox">
			<h3>vue中provide/inject怎么使用(圖文示例)</h3>
			<div>大劍師蘭特, 還是大劍師蘭特,gis-dajianshi</div>
		</div>
		<div class="dajianshi">
               <ComA></ComA>
		</div>
	</div>
</template>
<script>
	import ComA from '../components/provideInject/demo-A.vue';
	export default {
		components:{
			ComA
		},
		  provide() {
		    return {
		      message: 'Hello from ROOT-message',
			  message2: 'Hello from ROOT-message2'
		    };
		  }
	}
</script>
<style scoped>
	.djs-box {
		width: 1000px;
		height: 650px;
		margin: 50px auto;
		border: 1px solid teal;
	}
	.topBox {
		margin: 0 auto 0px;
		padding: 10px 0 20px;
		background: teal;
		color: #fff;
	}
	.dajianshi {
		width: 98%;
		height: 480px;
		margin: 5px auto 0;
		display: flex;
		justify-content: space-between;
		border:1px solid #369;
	}
</style>

子組件代碼

/*
* @Author: 大劍師蘭特(xiaozhuanlan),還是大劍師蘭特(CSDN)
* @此源代碼版權(quán)歸大劍師蘭特所有,可供學(xué)習(xí)或商業(yè)項(xiàng)目中借鑒,未經(jīng)授權(quán),不得重復(fù)地發(fā)表到博客、論壇,問(wèn)答,git等公共空間或網(wǎng)站中。
* @Email: 2909222303@qq.com
* @weixin: gis-dajianshi
* @First published in CSDN
* @First published time: 2024-02-04
*/
<template>
	<div style="margin-top: 100px;">
		<div class="left">
			<h2>兒子組件從跟組件獲取的信息message:</h2>
			<div style="color: blue;">{{message}}</div>
		</div>
		<div class="right">
			<h2>孫子組件從跟組件獲取的內(nèi)容message2:</h2>
			<ChildA></ChildA>
		</div>
	</div>
</template>
<script>
   	import ChildA from '@/components/provideInject/demo-A-A.vue';
	export default {
		inject: ['message'],
		components:{
			 ChildA
		},
	}
</script>
<style scoped>
	.left{ width: 48%; float:left;}
	.right{ width: 48%; float:right; height:300px; border:1px solid #ddd;}
</style>

孫組件代碼

/*
* @Author: 大劍師蘭特(xiaozhuanlan),還是大劍師蘭特(CSDN)
* @此源代碼版權(quán)歸大劍師蘭特所有,可供學(xué)習(xí)或商業(yè)項(xiàng)目中借鑒,未經(jīng)授權(quán),不得重復(fù)地發(fā)表到博客、論壇,問(wèn)答,git等公共空間或網(wǎng)站中。
* @Email: 2909222303@qq.com
* @weixin: gis-dajianshi
* @First published in CSDN
* @First published time: 2024-02-04
*/
<template>
	<div>
		<div style="color: red;">{{ message2 }}</div>
	</div>
</template>
<script>
	export default {
      inject: ['message2'],
	}
</script>

基本使用步驟

Vue中的provide和inject是用于實(shí)現(xiàn)依賴注入的API,其基本使用步驟如下:

  • 在父組件中使用provide:在父組件(祖先組件)的provide選項(xiàng)中,指定想要提供給后代組件的數(shù)據(jù)或方法。這些數(shù)據(jù)或方法可以是任意類型,包括函數(shù)、對(duì)象、原始值等。
  • 在子組件中使用inject:在任何后代組件中,通過(guò)inject選項(xiàng)來(lái)接收父組件提供的數(shù)據(jù)或方法。inject可以是一個(gè)字符串?dāng)?shù)組,也可以是一個(gè)對(duì)象。如果是對(duì)象,可以指定鍵名與默認(rèn)值。
  • 傳遞非響應(yīng)式數(shù)據(jù):需要注意的是,通過(guò)provide/inject傳遞的數(shù)據(jù)不會(huì)自動(dòng)變成響應(yīng)式的。如果需要在子組件中監(jiān)聽這些數(shù)據(jù)的變化,可能需要結(jié)合Vue的響應(yīng)式系統(tǒng)進(jìn)行處理。
  • 解決逐級(jí)傳遞問(wèn)題:provide/inject特別適用于解決跨多個(gè)層級(jí)的組件間數(shù)據(jù)傳遞問(wèn)題,避免了通過(guò)props逐級(jí)傳遞的繁瑣過(guò)程。

到此這篇關(guān)于vue中provide、inject的使用方法的文章就介紹到這了,更多相關(guān)vue provide、inject使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論