Vue2.0中三種常用傳值方式(父傳子、子傳父、非父子組件傳值)
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)文章
element-ui修改el-form-item樣式的詳細(xì)示例
在使用element-ui組件庫的時候經(jīng)常需要修改原有樣式,下面這篇文章主要給大家介紹了關(guān)于element-ui修改el-form-item樣式的詳細(xì)示例,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11vue集成kindeditor富文本的實現(xiàn)示例代碼
這篇文章主要介紹了vue集成kindeditor富文本的實現(xiàn)示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06Vue動態(tài)組件?component?:is的使用代碼示范
vue?動態(tài)組件用于實現(xiàn)在指定位置上,動態(tài)加載不同的組件,這篇文章主要介紹了Vue動態(tài)組件?component?:is的使用,需要的朋友可以參考下2023-09-09