亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue中的父子組件傳值及傳方法

 更新時間:2023年11月18日 09:29:14   作者:Cherry?  
這篇文章主要介紹了Vue中的父子組件傳值及傳方法,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

傳值

父組件傳值給子組件

// 父組件
<template>
    <div>
        <!-- 父組件中引入子組件,并傳入子組件內(nèi)需要的值 -->
        <child :message="father"></child>
    </div>
</template>
<script>
    import child from './child'
    export default {
        data() {
            return {
                //定義需要傳入的值
                father: '傳給子組件的值'
            }
        },
        components: {
            child
        }
    }
</script>


// 子組件
<template>
    <div>
        <div>{{message}}</div>
    </div>
</template>
<script>
    export default {
        //在子組件中注冊props,并使用父組件中傳遞過來的數(shù)據(jù)
        props: {
            message: String
        },
    }
</script>

子組件傳值給父組件

// 父組件
<template>
    <div>
    <!--自定義事件child,事件名為parent(parent事件用于接收子組件傳遞過來的值)-->
        <parent @child="parent"></parent >
    </div>
</template>
<script>
    export default {
        data: {
            message: ''
        },
        methods: {
            parent(val) {
                this.message = val;
            }
        }
    }
</script>

// 子組件
<template>
    <div>
    <!--點擊按鈕觸發(fā)send事件,把message傳給父組件-->
        <button @click="send">Send</button>
    </div>
</template>

<script>
export default {
    data() {
        return {
            message: '我是子組件的消息'
        }
    },
    methods: {
        sendMes() {
            this.$emit('child', this.message);
        }
    }
}
</script>

調(diào)用方法

父組件調(diào)用子組件的方法

// 父組件
<template>
  <div @click="handleParent">
    <children ref="mychild"></children>
  </div>
</template>

<script>
  import children from 'children.vue'
  export default {
    components: {
      children
    },
    methods:{
      handleParent() {
        this.$refs.mychild.childMethod();
      }
    }
  }
</script>

// 子組件
<template>
  <div></div>
</template>

<script>
  export default {
    methods:{
      childMethod() {
        console.log('My name is child')
      }
    }
  }
</script>

子組件調(diào)用父組件的方法

// 父組件
<template>
  <div>
       <child @listenChild="showFrom"></child>
       <div>{{ value }}</div>
  </div>
</template>

<script>
import child from './compontents/child.vue'
export default {
    components:{child},
    data () {
        return {
        value:''
        }
    },
    methods: {
        showFrom(data){
            this.value = data
        },
    }
}
</script>

//子組件
<template>
  <button @click="send()">
     我是子組件,點擊我向父組件傳值
  </button>
</template>

<script>
  export default {
    data(){
      return {
        message:'子組件的數(shù)據(jù)'
      }
    },
    methods:{
      send() {
        this.$emit("listenChild",this.message)
      }
    }
  }
</script>

非父子組件

廣播自定義事件

handleClick(){
    //response為要傳的值
    this.$root.$emit('change',response)
}

處理自定義事件

handleClick(){
    this.$root.$on('change',(item)=>{
        console.log(item) //item就是廣播事件的response
    })
}

有時候會發(fā)生事件只被 emit 觸發(fā)了一次,但是回調(diào)函數(shù)卻被執(zhí)行了多次的現(xiàn)象。這種現(xiàn)象往往發(fā)生在頁面跳轉(zhuǎn)退出后重新進入的時候。

產(chǎn)生原因:

this.root.Bus.root.Bus. root.Bus.on 實際是向 Bus 容器中添加一個事件監(jiān)聽器,當(dāng)頁面跳轉(zhuǎn)時,原來的 vue 組件被注銷,但是原來 vue 組件向 Bus 容器中添加的事件監(jiān)聽器并不會被移除。

因此,當(dāng)下次進入這個 vue 組件對應(yīng)的頁面時,執(zhí)行到 this. root.Bus.root.Bus. root.Bus.on 時,又會向 Bus 容器中添加一個重復(fù)的事件監(jiān)聽器,以此類推,導(dǎo)致 Bus 容器中有很多個一模一樣的事件監(jiān)聽器,從而導(dǎo)致事件只被觸發(fā)一次,但是回調(diào)函數(shù)被執(zhí)行多次的現(xiàn)象。

解決方案:

在 vue 組件的 beforeDetory 鉤子函數(shù)中將本 vue 組件往 Bus 容器中添加的時間監(jiān)聽器全部手動移除。

//在vue對象的methods域中定義個函數(shù)專門移除事件監(jiān)聽器
offListener() {
    this.$root.Bus.off("事件名");
    this.$root.Bus.off("事件名");
    this.$root.Bus.off("事件名");
},

//在beforeDestroy鉤子中調(diào)用此函數(shù)
beforeDestroy() {
    this.offListener();
},

總結(jié)

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

相關(guān)文章

  • Nuxt 嵌套路由nuxt-child組件用法(父子頁面組件的傳值)

    Nuxt 嵌套路由nuxt-child組件用法(父子頁面組件的傳值)

    這篇文章主要介紹了Nuxt 嵌套路由nuxt-child組件用法(父子頁面組件的傳值),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • element的el-upload組件上傳文件跨域問題的幾種解決

    element的el-upload組件上傳文件跨域問題的幾種解決

    跨域問題網(wǎng)上搜索很多,感覺情況都不一樣,本文主要介紹了element的el-upload組件上傳文件跨域問題的幾種解決,具有一定的參考價值,感興趣的可以了解一下
    2024-03-03
  • 在Vue3中使用BabylonJs開發(fā)?3D的初體驗

    在Vue3中使用BabylonJs開發(fā)?3D的初體驗

    這篇文章主要介紹了在?Vue3?中使用?BabylonJs?開發(fā)?3D?是什么體驗,在本文中,向您展示了如何創(chuàng)建?Vue?組件、Babylon?類、在畫布上渲染場景以及創(chuàng)建?3D?網(wǎng)格,需要的朋友可以參考下
    2022-07-07
  • Vue仿百度搜索功能

    Vue仿百度搜索功能

    這篇文章主要為大家詳細介紹了Vue仿百度搜索功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • vue導(dǎo)出word純前端的實現(xiàn)方式

    vue導(dǎo)出word純前端的實現(xiàn)方式

    這篇文章主要介紹了vue導(dǎo)出word純前端的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue組件封裝上傳圖片和視頻的示例代碼

    Vue組件封裝上傳圖片和視頻的示例代碼

    這篇文章主要介紹了Vue封裝上傳圖片和視頻的組件,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-07-07
  • vue獲取當(dāng)前路由的五種方式示例代碼

    vue獲取當(dāng)前路由的五種方式示例代碼

    這篇文章主要給大家介紹了關(guān)于vue獲取當(dāng)前路由的五種方式,文中通過代碼示例介紹的非常詳細,對大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2023-08-08
  • element中TimePicker時間選擇器禁用部分時間(顯示禁用到分鐘)

    element中TimePicker時間選擇器禁用部分時間(顯示禁用到分鐘)

    這篇文章主要介紹了element中TimePicker時間選擇器禁用部分時間(顯示禁用到分鐘),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • vue項目中禁用瀏覽器緩存配置案例

    vue項目中禁用瀏覽器緩存配置案例

    這篇文章主要介紹了vue項目中禁用瀏覽器緩存配置案例,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-09-09
  • Vuex之理解Getters的用法實例

    Vuex之理解Getters的用法實例

    這篇文章主要介紹了Vuex之理解Getters的用法實例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04

最新評論