内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

Vue組件實(shí)例間直接訪問的示例分析-創(chuàng)新互聯(lián)

小編給大家分享一下Vue組件實(shí)例間直接訪問的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯(lián)建站于2013年創(chuàng)立,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目成都做網(wǎng)站、網(wǎng)站設(shè)計(jì)網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元江南做網(wǎng)站,已為上家服務(wù),為江南各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:13518219792

前面的話

  有時(shí)候需要父組件訪問子組件,子組件訪問父組件,或者是子組件訪問根組件。 在組件實(shí)例中,Vue提供了相應(yīng)的屬性,包括$parent、$children、$refs和$root,這些屬性都掛載在組件的this上。

$parent 

  $parent表示父組件的實(shí)例,該屬性只讀

  下面是一個(gè)簡(jiǎn)易實(shí)例

<div id="example">
 <parent-component></parent-component>
</div>
<template id="parent-component">
 <div class="parent">
 <h4>我是父組件</h4>
 <input v-model="parentMsg">
 <p>{{parentMsg}}</p>
 <child-component></child-component> 
 </div>
</template>
<template id="child-component">
 <div class="child">
 <h4>我是子組件</h4>
 <p>{{msg}}</p>
 <button v-on:click="showData">顯示父組件數(shù)據(jù)</button> 
 </div>
</template>
<script>
// 注冊(cè)
Vue.component('parent-component', {
 template: '#parent-component',
 data(){
 return{
  parentMsg:'我是父組件的數(shù)據(jù)'
 }
 },
 components:{
 'child-component':{
  template:'#child-component',
  data(){
  return{
   msg:''
  }
  },
  methods:{
  showData(){
   this.msg = this.$parent.parentMsg;
  }
  }
 }
 }
})
// 創(chuàng)建根實(shí)例
new Vue({
 el: '#example'
})
</script>

$root 

  $root表示當(dāng)前組件樹的根 Vue 實(shí)例。如果當(dāng)前實(shí)例沒有父實(shí)例,此實(shí)例將會(huì)是其自己。該屬性只讀

<div id="example">
 <h4>我是根組件</h4>
 <input v-model="rootMsg">
 <p>{{rootMsg}}</p> 
 <parent-component></parent-component>
</div>
<template id="parent-component">
 <div class="parent">
 <h4>我是父組件</h4>
 <input v-model="parentMsg">
 <p>{{parentMsg}}</p>
 <child-component></child-component> 
 </div>
</template>
<template id="child-component">
 <div class="child">
 <h4>我是子組件</h4>
 <p>
  <button v-on:click="showRootData">顯示根組件數(shù)據(jù)</button><span>{{rootMsg}}</span>
 </p>  
 <p>
  <button v-on:click="showParentData">顯示父組件數(shù)據(jù)</button><span>{{parentMsg}}</span>
 </p>
 </div>
</template>
<script>
// 注冊(cè)
Vue.component('parent-component', {
 template: '#parent-component',
 data(){
 return{
  parentMsg:'我是父組件的數(shù)據(jù)'
 }
 },
 components:{
 'child-component':{
  template:'#child-component',
  data(){
  return{
   parentMsg:'',
   rootMsg:''
  }
  },
  methods:{
  showParentData(){
   this.parentMsg = this.$parent.parentMsg;
  },
  showRootData(){
   this.rootMsg = this.$root.rootMsg;
  },  
  }
 }
 }
})
// 創(chuàng)建根實(shí)例
new Vue({
 el: '#example',
 data:{
 rootMsg:'我是根組件數(shù)據(jù)'
 }
})
</script>

$children 

  $children表示當(dāng)前實(shí)例的直接子組件。需要注意$children并不保證順序,也不是響應(yīng)式的。如果正在嘗試使用$children來進(jìn)行數(shù)據(jù)綁定,考慮使用一個(gè)數(shù)組配合v-for來生成子組件,并且使用Array作為真正的來源

<div id="example">
 <parent-component></parent-component>
</div>
<template id="parent-component">
 <div class="parent">
 <h4>我是父組件</h4>
 <button @click="getData">獲取子組件數(shù)據(jù)</button>
 <br>
 <div v-html="msg"></div>
 <child-component1></child-component1> 
 <child-component2></child-component2> 
 </div>
</template>
<template id="child-component1">
 <div class="child">
 <h4>我是子組件1</h4>
 <input v-model="msg">
 <p>{{msg}}</p>
 </div>
</template>
<template id="child-component2">
 <div class="child">
 <h4>我是子組件2</h4>
 <input v-model="msg">
 <p>{{msg}}</p>
 </div>
</template>
<script>
// 注冊(cè)
Vue.component('parent-component', {
 template: '#parent-component',
 data(){
 return{
  msg:'',
 }
 },
 methods:{
 getData(){
  let html = '';
  let children = this.$children;
  for(var i = 0; i < children.length;i++){
  html+= '<div>' + children[i].msg + '</div>';
  }
  this.msg = html;
 }
 },
 components:{
 'child-component1':{
  template:'#child-component1',
  data(){
  return{
   msg:'',
  }
  },
 },
 'child-component2':{
  template:'#child-component2',
  data(){
  return{
   msg:'',
  }
  },
 }, 
 } 
})
// 創(chuàng)建根實(shí)例
new Vue({
 el: '#example',
})
</script>

$refs

  組件個(gè)數(shù)較多時(shí),難以記住各個(gè)組件的順序和位置,通過序號(hào)訪問子組件不是很方便

  在子組件上使用ref屬性,可以給子組件指定一個(gè)索引ID:

<child-component1 ref="c1"></child-component1>
<child-component2 ref="c2"></child-component2>

  在父組件中,則通過$refs.索引ID訪問子組件的實(shí)例

this.$refs.c1

this.$refs.c2

<div id="example">
 <parent-component></parent-component>
</div>
<template id="parent-component">
 <div class="parent">
 <h4>我是父組件</h4>
 <div>
  <button @click="getData1">獲取子組件c1的數(shù)據(jù)</button>
  <p>{{msg1}}</p>
 </div>
 <div>
  <button @click="getData2">獲取子組件c2的數(shù)據(jù)</button>
  <p>{{msg2}}</p>
 </div>
 <child-component1 ref="c1"></child-component1> 
 <child-component2 ref="c2"></child-component2> 
 </div>
</template>
<template id="child-component1">
 <div class="child">
 <h4>我是子組件1</h4>
 <input v-model="msg">
 <p>{{msg}}</p>
 </div>
</template>
<template id="child-component2">
 <div class="child">
 <h4>我是子組件2</h4>
 <input v-model="msg">
 <p>{{msg}}</p>
 </div>
</template>
<script>
// 注冊(cè)
Vue.component('parent-component', {
 template: '#parent-component',
 data(){
 return{
  msg1:'',
  msg2:'',
 }
 },
 methods:{
 getData1(){
  this.msg1 = this.$refs.c1.msg;
 },
 getData2(){
  this.msg2 = this.$refs.c2.msg;
 }, 
 },
 components:{
 'child-component1':{
  template:'#child-component1',
  data(){
  return{
   msg:'',
  }
  },
 },
 'child-component2':{
  template:'#child-component2',
  data(){
  return{
   msg:'',
  }
  },
 }, 
 } 
})
// 創(chuàng)建根實(shí)例
new Vue({
 el: '#example',
})
</script>

以上是“Vue組件實(shí)例間直接訪問的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)成都做網(wǎng)站行業(yè)資訊頻道!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

新聞標(biāo)題:Vue組件實(shí)例間直接訪問的示例分析-創(chuàng)新互聯(lián)
鏈接地址:http://m.rwnh.cn/article36/hcipg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT微信公眾號(hào)、響應(yīng)式網(wǎng)站、自適應(yīng)網(wǎng)站搜索引擎優(yōu)化、微信小程序

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司
乳山市| 满洲里市| 资溪县| 南京市| 黄陵县| 湘潭县| 句容市| 渑池县| 绥阳县| 茶陵县| 望奎县| 凤翔县| 双江| 波密县| 从化市| 习水县| 陆良县| 东平县| 邵阳县| 合江县| 高青县| 嵩明县| 会理县| 临颍县| 卫辉市| 绵竹市| 青龙| 吉林省| 亳州市| 逊克县| 湘乡市| 牡丹江市| 双峰县| 江华| 上栗县| 建水县| 会泽县| 泾源县| 汤原县| 绩溪县| 和田县|