国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

vue基礎(chǔ)知識(shí)--axios合并請(qǐng)求和slot

瀏覽:2日期:2023-01-16 10:25:12

一、axios合并請(qǐng)求

export default { data(){ return {} }, created(){ function getMsg(res1,res2){ console.log(res1) console.log(res2) } this.$axios.all([this,axios.post(’URL’,’key=value’),this.axios.get(’URL’) ]) .then(this.$axios.spread(getMsg)) //分發(fā)響應(yīng) .catch(err => { console.log(err) }) }}

這樣可以實(shí)現(xiàn)發(fā)送兩個(gè)請(qǐng)求,只有所有都成功,才算是成功。只要有一個(gè)失敗,就算是失敗。

二、插槽slot

1.基本用法

插槽的出現(xiàn)使得我們可以在使用子組件時(shí)在子組件內(nèi)新增內(nèi)容,而不僅僅是簡單的使用,呈現(xiàn)出多樣化的子組件。

<navigation-link> Your Profile</navigation-link>

當(dāng)我們使用子組件navigation時(shí),在子組件中寫入一些內(nèi)容,但是如果我們子組件的template中沒有一個(gè)插槽slot,那么我們寫入的Your Profile沒有的地方放,子組件怎么知道要放在哪里呢,不知道放在哪里,所以它就干脆不放了,會(huì)把寫的內(nèi)容拋棄,大家就當(dāng)無事發(fā)生過,子組件里怎么寫,它就怎么呈現(xiàn),全然不顧你在使用時(shí)寫入的東西,當(dāng)做沒有看見。但是如果我們?cè)谧咏M件中寫入了一個(gè)插槽slot,那么我們傳入的內(nèi)容將會(huì)被在這個(gè)插槽處呈現(xiàn)。像下面這樣

<a v-bind:href='http://www.cgvv.com.cn/bcjs/url' rel='external nofollow' rel='external nofollow' class='nav-link'> <slot></slot></a>

渲染出來的結(jié)果將是:

<a v-bind:href='http://www.cgvv.com.cn/bcjs/url' rel='external nofollow' rel='external nofollow' class='nav-link'> Your Profile</a>

2.具名插槽

有時(shí)候,我們需要在子組件中放置多個(gè)內(nèi)容,那么你只有一個(gè)slot,它只能全部放在這里(其實(shí)我也不知道是不是這樣我沒有試過),如果你有多個(gè)slot,它怎么知道哪個(gè)內(nèi)容要放在哪個(gè)slot,按順序放嗎?不是的(其實(shí)我也不知道是不是)。正確的做法就是使用具名插槽。所謂具名插槽就是一個(gè)帶有name的slot。也就是下面這樣

<!--base-layout.vue--><div class='container'> <header> <slot name='header'></slot> </header> <main> <slot></slot> <!--默認(rèn)插槽--> </main> <footer> <slot name='footer'></slot> </footer></div>

然后在使用上面這個(gè)子組件時(shí)像下面這樣

<base-layout> <template slot='header'> <h1>Here might be a page title</h1> </template> <p>A paragraph for the main content.</p> <p>And another one.</p> <template slot='footer'> <p>Here’s some contact info</p> </template></base-layout>

在使用時(shí),通過一個(gè)具有slot屬性的標(biāo)簽,屬性值對(duì)應(yīng)slot的name,將內(nèi)容放到子組件的相應(yīng)位置上去。

我們注意到,里面有一個(gè)沒有指定name的slot,它就是默認(rèn)插槽。所有在使用子組件時(shí)傳入的東西,只要沒有指定slot=’slot的name’,就都會(huì)放在這里。

我們還注意到,這里用的一個(gè)叫做template的標(biāo)簽,一定要用它嗎?不是的,也可以直接放在h1或者p上面,像下面這樣

<base-layout> <h1 slot='header'>Here might be a page title</h1> <p>A paragraph for the main content.</p> <p>And another one.</p> <p slot='footer'>Here’s some contact info</p></base-layout>

但是,如果你并不只有一個(gè)h1,你還有其他內(nèi)容也要一起放在這個(gè)插槽里,那你能怎么辦,為每一個(gè)要放在插槽里的標(biāo)簽加slot嗎?太麻煩啦!所以就一起放在template里面,給template加slot咯。

3.插槽的默認(rèn)內(nèi)容

有時(shí)候,我們也需要為某個(gè)插槽指定默認(rèn)內(nèi)容。比如一個(gè)按鈕,默認(rèn)顯示是 submit ,但我們有時(shí)在復(fù)用它的時(shí)候,我們又想改成別的,這個(gè)時(shí)候,就可以把這個(gè)按鈕的 submit 放在slot里面,然后在使用這個(gè)子組件的時(shí)候,放你要改的東西去改變它。如果沒有放,那就是默認(rèn)的 submit。

<button type='submit'> <slot>Submit</slot> <!--Submit就是插槽的默認(rèn)內(nèi)容--></button>

4.作用域

在插槽中傳值時(shí),如果想要使用數(shù)據(jù),這個(gè)數(shù)據(jù)應(yīng)該是父組件的,而不能是子組件的。也就是說是使用子組件的那個(gè)組件的data。

<navigation-link url='/profile'> Logged in as {{ user.name }} </navigation-link>

這里的user不是navigation-link的,而是父組件的

牢記一條準(zhǔn)則:父組件模板的所有東西都會(huì)在父級(jí)作用域內(nèi)編譯;子組件模板的所有東西都會(huì)在子級(jí)作用域內(nèi)編譯。

5.作用域插槽 【2.1.0+ 新增】(我也不知道為什么要叫這個(gè)名字,和插槽的作用于太像,很容易搞混啊)

上面我們提到,插槽是具有作用于的,且當(dāng)我們?cè)谑褂米咏M件時(shí),是無法獲取子組件的數(shù)據(jù)的。而有時(shí),我們又需要獲取它,那么應(yīng)該怎么辦呢?

比如一個(gè)名為todo-list的子組件,它的內(nèi)容如下:

<ul> <li v-for='todo in todos' v-bind:key='todo.id'> {{ todo.text }} </li></ul>

這時(shí),這里所獲取的數(shù)據(jù)是子組件自己內(nèi)部的數(shù)據(jù)。而我們?cè)谑褂眠@個(gè)子組件時(shí)是無法獲取它的(當(dāng)然我們可以用以前學(xué)習(xí)過的父子組件間的通訊來實(shí)現(xiàn)),我們可以利用slot來達(dá)到這個(gè)目的

<ul> <li v-for='todo in todos' v-bind:key='todo.id' > <!-- 我們?yōu)槊總€(gè) todo 準(zhǔn)備了一個(gè)插槽,--> <!-- 將 `todo` 對(duì)象作為一個(gè)插槽的 prop 傳入。--> <slot v-bind:todo='todo'> <!-- 回退的內(nèi)容 --> {{ todo.text }} </slot> </li></ul>

然后當(dāng)我們使用todo-list組件的是時(shí)候,可以這樣做

<todo-list v-bind:todos='todos'> <!-- 將 `slotProps` 定義為插槽作用域的名字 --> <template slot-scope='slotProps'> <!-- 為待辦項(xiàng)自定義一個(gè)模板,--> <!-- 通過 `slotProps` 定制每個(gè)待辦項(xiàng)。--> <span v-if='slotProps.todo.isComplete'>✓</span> {{ slotProps.todo.text }} </template></todo-list>

這時(shí)即使我們是在父組件中,也還是可以獲取到子組件的數(shù)據(jù)。其中slotProps只是一個(gè)名字,我們用slot-scope指定為什么名字,就可以在下面用xx.來獲取子組件的data在 2.5.0+,slot-scope 不再限制在 <template> 元素上使用,而可以用在插槽內(nèi)的任何元素或組件上。

以上就是詳解vue中的axios和slot的詳細(xì)內(nèi)容,更多關(guān)于vue axios和slot的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: IOS
相關(guān)文章:
主站蜘蛛池模板: 一级毛片在线观看视频 | 久久久久18 | 美女视频免费看视频网站 | 97视频在线免费 | 亚洲在线不卡 | 男女性高爱潮免费网站 | 久久精品国产精品亚洲精品 | 91成人免费在线视频 | 国产三级毛片视频 | 韩国美女爽快毛片免费 | 久久精品国产亚洲网站 | 能看毛片的网址 | 亚洲一区二区三区在线视频 | 国产91精品高清一区二区三区 | 欧美高清强视频 | 久久久午夜精品理论片 | 精品国产一区二区三区久 | 久草在线视频网站 | 足恋玩丝袜脚视频免费网站 | 亚洲爽妇网| 精品一区二区三区的国产在线观看 | 三级精品在线观看 | 亚洲成人在线免费观看 | 欧美最黄视频 | 在线观看亚洲免费 | 欧美午夜不卡在线观看最新 | 久久精品国产精品亚洲人人 | 国外免费一级 | 嫩草一区二区三区四区乱码 | 日韩精品另类天天更新影院 | 中文字幕有码视频 | 中文字幕 亚洲 一区二区三区 | 狠狠色狠狠综合久久 | 国产美女午夜精品福利视频 | 一区视频在线 | 欧美成人免费在线观看 | 亚洲综合亚洲 | 香蕉99国内自产自拍视频 | 国产一区二区亚洲精品 | 9久9久热精品视频在线观看 | 在线免费观看一级毛片 |