欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue?props傳入function時的this指向問題解讀

 更新時間:2023年01月21日 09:03:36   作者:__Simon  
這篇文章主要介紹了Vue?props傳入function時的this指向問題解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

Vue props傳入function時的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ù)中this自動綁定Vue實例;

在H5的Vue中項目中,console將輸出 “this is parent.”;

但在uni-app小程序中使用Vue時,console將輸出“this is child”;

我的解決方案

將父組件msg作為參數(shù)傳給子組件,子組件props接收msg,然后在父組件的parantFunc中,無論this 指向父組件還是子組件,this.msg總能取得正確的值;

為什么不使用v-on監(jiān)聽子組件事件并用$emit觸發(fā)事件?

  • Vue中不推薦向子組件傳遞Function的方式,因為Vue有更好的事件父子組件通信機(jī)制;
  • 我的原因:項目中的子組件是一個公共組件,原本的代碼是使用props+Function的方式,且存在默認(rèn)值,默認(rèn)調(diào)用函數(shù)default默認(rèn)值;如果改為事件$emit的方式,則涉及修改的地方較多;
  • 因此,在盡量不影響原來的業(yè)務(wù)代碼的原則下,采用上述解決方案解決該問題;

Vue props 傳遞函數(shù)

Props的type是函數(shù)

通過 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)">點擊加 1 </button>
    </div>
</template>
<script>
export default {
    data() {
        return {
            count:1,
        }
    },
    props:{
        add:{
            type: Function
        }
    },
    methods: {
        handClick(){
            this.add( ++this.count); // 父組件方法
        }
    },
}

結(jié)果

可以看到 chirden 組件在中 使用 props.add() , 調(diào)用的是 父組件的方法。

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue動態(tài)路由匹配和路由懶加載多種方法詳解

    vue動態(tài)路由匹配和路由懶加載多種方法詳解

    這篇文章主要介紹了vue動態(tài)路由匹配和路由懶加載,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-06-06
  • 超詳細(xì)圖解如何運行vue項目

    超詳細(xì)圖解如何運行vue項目

    Vue是一套用于構(gòu)建用戶界面的漸進(jìn)式框架,它的核心庫只關(guān)注視圖層,易于上手,也便于與其他庫或已有項目整合,下面這篇文章主要給大家介紹了關(guān)于如何運行vue項目的相關(guān)資料,需要的朋友可以參考下
    2023-05-05
  • vue?代碼壓縮優(yōu)化方式

    vue?代碼壓縮優(yōu)化方式

    這篇文章主要介紹了vue?代碼壓縮優(yōu)化方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • VUE+node(express)實現(xiàn)前后端分離

    VUE+node(express)實現(xiàn)前后端分離

    在本篇文章里小編給大家分享的是關(guān)于VUE+node(express)前后端分離實例內(nèi)容,有需要的朋友們參考下。
    2019-10-10
  • 一文詳解VueUse中useAsyncState的實現(xiàn)原理

    一文詳解VueUse中useAsyncState的實現(xiàn)原理

    在Vue 3 Composition API中,我們可以使用自定義鉤子函數(shù)來封裝可復(fù)用的邏輯,useAsyncState是一個用于管理異步狀態(tài)的自定義鉤子函數(shù),本文將給大家介紹一下useAsyncState的實現(xiàn)原理,感興趣的朋友可以參考下
    2024-01-01
  • 淺談Vue.nextTick 的實現(xiàn)方法

    淺談Vue.nextTick 的實現(xiàn)方法

    本篇文章主要介紹了Vue.nextTick 的實現(xiàn)方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • vue表單驗證rules及validator驗證器的使用方法實例

    vue表單驗證rules及validator驗證器的使用方法實例

    在vue開發(fā)中,難免遇到各種表單校驗,下面這篇文章主要給大家介紹了關(guān)于vue表單驗證rules及validator驗證器使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • vue數(shù)據(jù)雙向綁定的注意點

    vue數(shù)據(jù)雙向綁定的注意點

    這篇文章主要為大家詳細(xì)介紹了vue數(shù)據(jù)雙向綁定的注意點,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • vite+vue3項目集成ESLint與prettier的過程詳解

    vite+vue3項目集成ESLint與prettier的過程詳解

    這篇文章主要介紹了vite+vue3項目中集成ESLint與prettier的相關(guān)知識,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-09-09
  • 詳解Vue實現(xiàn)鏈接生成二維碼并支持下載

    詳解Vue實現(xiàn)鏈接生成二維碼并支持下載

    在現(xiàn)代 Web 應(yīng)用中,快速分享鏈接是一項常見需求,二維碼作為一種簡潔的分享方式,受到了廣泛歡迎,所以本文將介紹如何使用 Vue 純前端技術(shù)實現(xiàn)動態(tài)生成鏈接二維碼的方法,需要的可以參考下
    2024-03-03

最新評論