国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

巧妙運用v-model實現父子組件傳值的方法示例

2024-05-06 15:41:00
字體:
來源:轉載
供稿:網友

v-model介紹

熟悉Vue的小伙伴們都知道 v-model 是Vue的一個很大的特色,可以實現雙向數據綁定。但本質上呢,它不過是語法糖,它負責監聽用戶的輸入事件以更新數據。
以下摘取自Vue官方文檔

v-model 在內部使用不同的屬性為不同的輸入元素并拋出不同的事件:

text 和 textarea 使用 value 屬性和 input 事件; checkbox 和 radio 使用 checked 屬性和 change 事件; select 字段將 value 作為 prop 并將 change 作為事件。

如何巧妙利用 v-model實現父子組件傳值

通常子組件某個變量更新,并需要告知父組件時,需要子組件觸發事件并父組件監聽該事件。

但是熟悉上面 v-model 的實現原理后,我們可以巧妙地運用這一原理(v-model 在內部使用不同的屬性為不同的輸入元素并拋出不同的事件)。

方法總結:

1.子組件設 value 為props屬性,并且不主動改變 value 值
2.子組件通過 this.$emit('input', 'updateValue') 將 updateValue 值傳給父組件
3.父組件通過 v-model="localValue" 綁定一個本地變量,即可實現子組件value值與父組件updateValue 值同步更新

舉例

子組件

子組件,包含一個button,并且將 value 屬性設為props( 因為v-model使用的是 value屬性 )。

點擊button時,sum值加1,同時通過 this.$emit('input', ++sum) 將更新后的值傳給父組件(前提:傳給父組件的值一定是你想賦給 value 的)

<template> <div>  <button @click="increase" style="border: 1px solid black">increase</button> </div></template><script>let sum = 0export default { name: 'vmodel', props: {  value: {   type: Number,   default: 0  } }, methods: {  increase () {   this.$emit('input', ++sum)   console.log('value1', this.value)     setTimeout(() => {    console.log('value2', this.value)   }, 50)  } }}</script>

父組件

父組件中,通過 v-model 綁定一個本地變量,即可實現子父組件同步更新

<div>  <increase v-model="rangeValue"></increase>  <p>value:{{rangeValue}}</p></div><script>data () {  return {   rangeValue: 0  }}</script>

實際上,這個過程是首先子組件通過 $emit('input') 更新父組件的本地變量,然后子組件中的 value 屬性通過 props 得以更新

總結

這種方式尤其適合子父組件傳參的情況(子父組件同步更新)

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持錯新站長站。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 神木县| 平利县| 厦门市| 桂东县| 佳木斯市| 沙洋县| 福鼎市| 沙雅县| 原阳县| 汾阳市| 江北区| 梨树县| 宜昌市| 永安市| 阳新县| 鹤峰县| 永平县| 屏边| 安泽县| 扎兰屯市| 邳州市| 兴隆县| 石泉县| 三门县| 探索| 平南县| 瑞金市| 舟曲县| 淄博市| 轮台县| 博爱县| 嵊州市| 宜宾县| 洪泽县| 邮箱| 保山市| 紫阳县| 来安县| 都匀市| 左云县| 喜德县|