Vue?props傳入function時(shí)的this指向問(wèn)題解讀
Vue props傳入function時(shí)的this指向
Parent.vue
<template>
<div>
<Child :func="parentFunc"></Child>
</div>
</template>
<script>
import Child from './Child'
export default {
data () {
return {
msg: 'this is parent.'
}
},
components: {
Child
},
methods: {
parentFunc () {
console.log(this.msg)
}
}
}
</script>
Child.vue
<template>
<div>
<button @click="childFunc">click</button>
</div>
</template>
<script>
export default {
props: {
func: {
require: false,
type: Function,
default: () => {
return () => {
console.log(this.msg)
}
}
}
},
data () {
return {
msg: 'this is child.'
}
},
methods: {
childFunc () {
this.func()
}
}
}
</script>
踩坑筆記
props傳入function時(shí),函數(shù)中this自動(dòng)綁定Vue實(shí)例;
在H5的Vue中項(xiàng)目中,console將輸出 “this is parent.”;
但在uni-app小程序中使用Vue時(shí),console將輸出“this is child”;
我的解決方案
將父組件msg作為參數(shù)傳給子組件,子組件props接收msg,然后在父組件的parantFunc中,無(wú)論this 指向父組件還是子組件,this.msg總能取得正確的值;
為什么不使用v-on監(jiān)聽(tīng)子組件事件并用$emit觸發(fā)事件?
- Vue中不推薦向子組件傳遞Function的方式,因?yàn)閂ue有更好的事件父子組件通信機(jī)制;
- 我的原因:項(xiàng)目中的子組件是一個(gè)公共組件,原本的代碼是使用props+Function的方式,且存在默認(rèn)值,默認(rèn)調(diào)用函數(shù)default默認(rèn)值;如果改為事件$emit的方式,則涉及修改的地方較多;
- 因此,在盡量不影響原來(lái)的業(yè)務(wù)代碼的原則下,采用上述解決方案解決該問(wèn)題;
Vue props 傳遞函數(shù)
Props的type是函數(shù)
通過(guò) props 傳遞 函數(shù) 看看有啥用。
// 父組件
</template>
<div>
<children :add='childrenClick'></children>
<p>{{countF}}</p>
</div>
</template>
<script>
import children from './Children'
export default {
name: 'HelloWorld',
data() {
return {
countF: 0,
}
},
methods: {
childrenClick(c){
this.countF += c;
}
},
components:{
children,
}
}
</script>
// 子組件
<template>
<div>
<button @click="handClick(count)">點(diǎn)擊加 1 </button>
</div>
</template>
<script>
export default {
data() {
return {
count:1,
}
},
props:{
add:{
type: Function
}
},
methods: {
handClick(){
this.add( ++this.count); // 父組件方法
}
},
}

可以看到 chirden 組件在中 使用 props.add() , 調(diào)用的是 父組件的方法。
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue動(dòng)態(tài)路由匹配和路由懶加載多種方法詳解
這篇文章主要介紹了vue動(dòng)態(tài)路由匹配和路由懶加載,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-06-06
超詳細(xì)圖解如何運(yùn)行vue項(xiàng)目
Vue是一套用于構(gòu)建用戶界面的漸進(jìn)式框架,它的核心庫(kù)只關(guān)注視圖層,易于上手,也便于與其他庫(kù)或已有項(xiàng)目整合,下面這篇文章主要給大家介紹了關(guān)于如何運(yùn)行vue項(xiàng)目的相關(guān)資料,需要的朋友可以參考下2023-05-05
VUE+node(express)實(shí)現(xiàn)前后端分離
在本篇文章里小編給大家分享的是關(guān)于VUE+node(express)前后端分離實(shí)例內(nèi)容,有需要的朋友們參考下。2019-10-10
一文詳解VueUse中useAsyncState的實(shí)現(xiàn)原理
在Vue 3 Composition API中,我們可以使用自定義鉤子函數(shù)來(lái)封裝可復(fù)用的邏輯,useAsyncState是一個(gè)用于管理異步狀態(tài)的自定義鉤子函數(shù),本文將給大家介紹一下useAsyncState的實(shí)現(xiàn)原理,感興趣的朋友可以參考下2024-01-01
淺談Vue.nextTick 的實(shí)現(xiàn)方法
本篇文章主要介紹了Vue.nextTick 的實(shí)現(xiàn)方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-10-10
vue表單驗(yàn)證rules及validator驗(yàn)證器的使用方法實(shí)例
在vue開(kāi)發(fā)中,難免遇到各種表單校驗(yàn),下面這篇文章主要給大家介紹了關(guān)于vue表單驗(yàn)證rules及validator驗(yàn)證器使用的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07
vite+vue3項(xiàng)目集成ESLint與prettier的過(guò)程詳解
這篇文章主要介紹了vite+vue3項(xiàng)目中集成ESLint與prettier的相關(guān)知識(shí),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09
詳解Vue實(shí)現(xiàn)鏈接生成二維碼并支持下載
在現(xiàn)代 Web 應(yīng)用中,快速分享鏈接是一項(xiàng)常見(jiàn)需求,二維碼作為一種簡(jiǎn)潔的分享方式,受到了廣泛歡迎,所以本文將介紹如何使用 Vue 純前端技術(shù)實(shí)現(xiàn)動(dòng)態(tài)生成鏈接二維碼的方法,需要的可以參考下2024-03-03

