溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

利用VUE實現子組件向父組件傳值的方法

發布時間:2020-11-05 18:13:24 來源:億速云 閱讀:245 作者:Leah 欄目:開發技術

利用VUE實現子組件向父組件傳值的方法?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

一、子組件向父組件傳遞一個值

子組件:

this.$emit('change', this.value);

父組件:

<!-- 在父組件中使用子組件 -->
<editable-cell :text="text" :inputType="inputType" @change="costPlannedAmountChange($event)" />
// 事件處理函數
async costPlannedAmountChange(value) {
	console.log(value)
}

在使用子組件時,綁定change函數的事件處理函數也可以寫成如下格式:

<editable-cell :text="text" :inputType="inputType" @change="costPlannedAmountChange" />

綁定事件處理函數時,可以不帶括號,形參則默認為事件對象,如果綁定時帶上了括號,再想使用事件對象則需要傳入$event作為實參。

二、子組件向父組件傳遞一個值,并攜帶額外參數

record為額外參數( 本文的額外參數都拿record做舉例 )。

子組件:

this.$emit('change', this.value);

父組件:

<!-- 插槽 -->
<template slot="planned_amount" slot-scope="text, record">
 <!-- 在父組件中使用子組件 -->
 <editable-cell :text="text" :inputType="inputType" @change="costPlannedAmountChange(record,$event)" />
</template>
// 事件處理函數
async costPlannedAmountChange(record,value) {
 console.log(record,value)
},

綁定事件處理函數時,record和$event的順序不做要求,但是按照vue事件綁定的習慣,$event通常放在實參列表末尾。

三、子組件向父組件傳遞多個值

子組件:

// 向父組件傳遞了兩個值
this.$emit('change', this.value,this.text);

父組件:

<editable-cell :text="text" :inputType="inputType" @change="costPlannedAmountChange" />
// 事件處理函數
async costPlannedAmountChange(param1,param2) {
  console.log(param1,param2)
},

綁定事件處理函數時,不能攜帶括號?。?!如果攜帶括號并且在括號內加了$event,只能拿到子組件傳遞過來的第一個參數。

四、子組件向父組件傳遞多個值,并攜帶額外參數

record為額外參數( 本文的額外參數都拿record做舉例 )。

子組件:

// 向父組件傳遞了兩個值
this.$emit('change', this.value,this.text);

父組件:

<template slot="planned_amount" slot-scope="text, record">
 <!-- 在父組件中使用子組件 -->
  <editable-cell :text="text" :inputType="inputType" @change="costPlannedAmountChange(record,arguments)" />
</template>
// 事件處理函數
async costPlannedAmountChange(record,args) {
  console.log(record,args)
},

arguments是方法綁定中的一個關鍵字,內部包括了所有方法觸發時傳遞過來的實參。arguments和額外參數的位置誰先誰后不做要求,建議arguments放后面。

查看args的打印結果:

利用VUE實現子組件向父組件傳值的方法

看完上述內容,你們掌握利用VUE實現子組件向父組件傳值的方法的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女