vue2和vue3子組件父組件之間的傳值方法
先看一下vue2
- 父組件向子組件傳遞參數
父組件通過
:語法 其實就是v-bind 來傳遞參數
子組件通過props來獲取父組件傳遞的方法
億點小知識:子組件接收到數據之后,不能直接修改父組件的數據。會報錯
// 父組件 parent 像子組件傳遞 msg 值
<template>
<Children :datum="'我是父組件的數據'"></Children>
</template>
?----------------------------------------------------------------------------------
// 子組件 接收 父組件 傳遞的數據
export default {
// 寫法一 用數組接收
props:['datum'],
// 寫法二 用對象接收,可以限定接收的數據類型、設置默認值、驗證等
props:{
datum:{
type:String,
default:'這是默認數據'
}
},
mounted(){
console.log(this.datum)// 我是父組件的數據
},
}- 子組件向父組件傳遞參數 (這里同時講了父組件向子組件傳遞方法)
父組件通過
@語法 其實就是v-on 來傳遞方法
子組件通過$emit來獲取父組件傳遞的方法 同時向父組件傳遞數據
<template>
<Children @method="method"></Children>
</template>
<script>
import Children from './Children';
export default {
components: {
Children
},
methods: {
method(data) { // 這里的 data 就是子組件傳遞的參數 如果參數擁有多個可以使用 ...語法獲取參數
console.log(data);// 子組件傳遞的參數
}
}
};
</script>
?----------------------------------------------------------------------------------
// 子組件 傳遞給 父組件數據
export default {
methods: {
childMethod() { // 子組件通過 $emit 獲取父組件傳遞的方法,然后攜帶數據傳給父組件
this.$emit('method',"我是子組件");
}
}
}- 父組件使用子組件的方法
vue2.0里面父組件調用子組件的方法是通過
$refs實現的
//父組件
<template>
<Children ref="child"></Children>
</template>
export default{
import Children from './Children'
export default{
components:{
Children
},
mounted:{
//調用子組件方法 這里要注意區(qū)分 child 是ref的名字
this.$refs.child.getData(val) //通過$refs找到子組件,并找到方法執(zhí)行
}
}
}以上就是 vue2 子組件父組件之間的通訊
vue3
相信能看懂 vue2的小伙伴 應該理解之間的通訊 這里我就直接在父組件和子組件進行通訊
- 父組件
<template>
<Children :title="我是父組件" ref="childrenRef" @method="methodChildren"></Children >
</template>
<script lang="ts">
import Children from "./Children.vue"
import { defineComponent, ref } from "vue"
export default defineComponent({
components: {
Children ,
},
setup() {
let msg = ref("")
let childrenRef = ref() // 通過ref獲取 子組件的實例
let fun = () =>{
childrenRef.value.fatherFun()// 使用子組件的方法
}
let methodChildren = (val) => {
msg.value = val // 這里val獲取子組件傳遞的值
}
return {
msg,
methodChildren,
}
},
})
</script>- 子組件
<template>
<!-- 點擊調用父組件的方法 -->
<button @click="fatherMethod">點擊</button>
</template>
<script lang="ts">
import { defineComponent } from "vue"
export default defineComponent({
name: "Children",
props: {
title: {
type: String,
},
},
setup(props, {emit}) {
const fatherMethod= () => {
emit("method", "傳值給父組件")
}
const fatherFun= () => {
console.log("我是子組件的方法")
}
return {
fatherMethod,
}
},
})
</script>以上就是vue2和vue3子組件父組件之間的傳值方法的詳細內容,更多關于vue2和vue3組件傳值的資料請關注腳本之家其它相關文章!
相關文章
vuex + keep-alive實現tab標簽頁面緩存功能
這篇文章主要介紹了vuex + keep-alive實現tab標簽頁面緩存功能,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-10-10
Vuex中的getter和mutation的區(qū)別詳解
在現代前端開發(fā)中,狀態(tài)管理是一個不可忽視的話題,而Vuex作為Vue.js的官方狀態(tài)管理庫,在大型應用中扮演著至關重要的角色,當我們使用Vuex進行狀態(tài)管理時,getter和mutation是兩個重要的概念,在本文中,我們將詳細探討getter和mutation的區(qū)別,需要的朋友可以參考下2024-12-12
vue.js利用Object.defineProperty實現雙向綁定
這篇文章主要為大家詳細介紹了vue.js利用Object.defineProperty實現雙向綁定,幫大家解析神秘的Object.defineProperty方法2017-03-03

