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

Vue2.0中三種常用傳值方式(父傳子、子傳父、非父子組件傳值)

 更新時間:2018年08月16日 09:52:42   作者:lander_xiong  
在Vue的框架開發(fā)的項目過程中,經(jīng)常會用到組件來管理不同的功能,有一些公共的組件會被提取出來。下面通過本文給大家介紹Vue開發(fā)中常用的三種傳值方式父傳子、子傳父、非父子組件傳值,需要的朋友參考下吧

Vue2.0 傳值方式:

在Vue的框架開發(fā)的項目過程中,經(jīng)常會用到組件來管理不同的功能,有一些公共的組件會被提取出來。這時必然會產(chǎn)生一些疑問和需求?比如一個組件調(diào)用另一個組件作為自己的子組件,那么我們?nèi)绾芜M(jìn)行給子組件進(jìn)行傳值呢?如果是電商網(wǎng)站系統(tǒng)的開發(fā),還會涉及到購物車的選項,這時候就會涉及到非父子組件傳值的情況。當(dāng)然你也可以用Vuex狀態(tài)管理工具來實現(xiàn),這部分我們后續(xù)會單獨介紹。我先給大家介紹Vue開發(fā)中常用的三種傳值方式。

Vue常用的三種傳值方式有:

•父傳子

•子傳父

•非父子傳值

引用官網(wǎng)的一句話:父子組件的關(guān)系可以總結(jié)為 prop 向下傳遞,事件向上傳遞。父組件通過 prop 給子組件下發(fā)數(shù)據(jù),子組件通過事件給父組件發(fā)送消息,如下圖所示:

這里寫圖片描述

接下來,我們通過實例來看可能會更明白一些:

1. 父組件向子組件進(jìn)行傳值

這里寫圖片描述

父組件:

<template>
 <div>
  父組件:
  <input type="text" v-model="name">
  <br>
  <br>
  <!-- 引入子組件 -->
  <child :inputName="name"></child>
 </div>
</template>
<script>
 import child from './child'
 export default {
  components: {
   child
  },
  data () {
   return {
    name: ''
   }
  }
 }
</script>

子組件:

<template>
 <div>
  子組件:
  <span>{{inputName}}</span>
 </div>
</template>
<script>
 export default {
  // 接受父組件的值
  props: {
   inputName: String,
   required: true
  }
 }
</script>

2. 子組件向父組件傳值

這里寫圖片描述

子組件:

<template>
 <div>
  子組件:
  <span>{{childValue}}</span>
  <!-- 定義一個子組件傳值的方法 -->
  <input type="button" value="點擊觸發(fā)" @click="childClick">
 </div>
</template>
<script>
 export default {
  data () {
   return {
    childValue: '我是子組件的數(shù)據(jù)'
   }
  },
  methods: {
   childClick () {
    // childByValue是在父組件on監(jiān)聽的方法
    // 第二個參數(shù)this.childValue是需要傳的值
    this.$emit('childByValue', this.childValue)
   }
  }
 }
</script>

父組件:

<template>
 <div>
  父組件:
  <span>{{name}}</span>
  <br>
  <br>
  <!-- 引入子組件 定義一個on的方法監(jiān)聽子組件的狀態(tài)-->
  <child v-on:childByValue="childByValue"></child>
 </div>
</template>
<script>
 import child from './child'
 export default {
  components: {
   child
  },
  data () {
   return {
    name: ''
   }
  },
  methods: {
   childByValue: function (childValue) {
    // childValue就是子組件傳過來的值
    this.name = childValue
   }
  }
 }
</script>

3. 非父子組件進(jìn)行傳值

非父子組件之間傳值,需要定義個公共的公共實例文件bus.js,作為中間倉庫來傳值,不然路由組件之間達(dá)不到傳值的效果。

公共bus.js

//bus.js
import Vue from 'vue'
export default new Vue()

組件A:

<template>
 <div>
  A組件:
  <span>{{elementValue}}</span>
  <input type="button" value="點擊觸發(fā)" @click="elementByValue">
 </div>
</template>
<script>
 // 引入公共的bug,來做為中間傳達(dá)的工具
 import Bus from './bus.js'
 export default {
  data () {
   return {
    elementValue: 4
   }
  },
  methods: {
   elementByValue: function () {
    Bus.$emit('val', this.elementValue)
   }
  }
 }
</script>

組件B:

<template>
 <div>
  B組件:
  <input type="button" value="點擊觸發(fā)" @click="getData">
  <span>{{name}}</span>
 </div>
</template>
<script>
 import Bus from './bus.js'
 export default {
  data () {
   return {
    name: 0
   }
  },
  mounted: function () {
   var vm = this
   // 用$on事件來接收參數(shù)
   Bus.$on('val', (data) => {
    console.log(data)
    vm.name = data
   })
  },
  methods: {
   getData: function () {
    this.name++
   }
  }
 }
</script>

 總結(jié)

以上所述是小編給大家介紹的Vue2.0中三種常用傳值方式(父傳子、子傳父、非父子組件傳值),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • vue中路由的前進(jìn)和后退問題

    vue中路由的前進(jìn)和后退問題

    這篇文章主要介紹了vue中路由的前進(jìn)和后退問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 完美解決iview 的select下拉框選項錯位的問題

    完美解決iview 的select下拉框選項錯位的問題

    下面小編就為大家分享一篇完美解決iview 的select下拉框選項錯位的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • element-ui修改el-form-item樣式的詳細(xì)示例

    element-ui修改el-form-item樣式的詳細(xì)示例

    在使用element-ui組件庫的時候經(jīng)常需要修改原有樣式,下面這篇文章主要給大家介紹了關(guān)于element-ui修改el-form-item樣式的詳細(xì)示例,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-11-11
  • vue項目實現(xiàn)左滑刪除功能(完整代碼)

    vue項目實現(xiàn)左滑刪除功能(完整代碼)

    最近在開發(fā)移動端項目,通過向左滑動出現(xiàn)刪除按鈕,點擊即可刪除,怎么實現(xiàn)這個功能呢,接下來小編給大家?guī)韺嵗a幫助大家學(xué)習(xí)vue項目實現(xiàn)左滑刪除功能,感興趣的朋友跟隨小編一起看看吧
    2021-05-05
  • vue集成kindeditor富文本的實現(xiàn)示例代碼

    vue集成kindeditor富文本的實現(xiàn)示例代碼

    這篇文章主要介紹了vue集成kindeditor富文本的實現(xiàn)示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • vue實現(xiàn)卡片翻轉(zhuǎn)輪播展示

    vue實現(xiàn)卡片翻轉(zhuǎn)輪播展示

    這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)卡片翻轉(zhuǎn)輪播展示,同時在翻轉(zhuǎn)時切換數(shù)據(jù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-01-01
  • Vue動態(tài)組件?component?:is的使用代碼示范

    Vue動態(tài)組件?component?:is的使用代碼示范

    vue?動態(tài)組件用于實現(xiàn)在指定位置上,動態(tài)加載不同的組件,這篇文章主要介紹了Vue動態(tài)組件?component?:is的使用,需要的朋友可以參考下
    2023-09-09
  • vue 解決異步數(shù)據(jù)更新問題

    vue 解決異步數(shù)據(jù)更新問題

    今天小編就為大家分享一篇vue 解決異步數(shù)據(jù)更新問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • 圖解Vue?響應(yīng)式流程及原理

    圖解Vue?響應(yīng)式流程及原理

    這篇文章主要為大家介紹了圖解Vue的響應(yīng)式原理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • vue實現(xiàn)橫向時間軸組件方式

    vue實現(xiàn)橫向時間軸組件方式

    這篇文章主要介紹了vue實現(xiàn)橫向時間軸組件方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12

最新評論