您好,登錄后才能下訂單哦!
vue項目中如何實現組件之間的數據共享和修改?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
我們在使用vue開發過程中會遇到這樣的情況,在父組件中引入了子組件,需要將父組件的值傳到子組件中顯示,同時子組件還可以更改父組件的值。
以我目前的一個項目的開發為例,如下圖頁面:
在父組件中,我引入了兩個子組件,一個是左邊的導航欄,還有中間的一個富文本編譯器組件,當我點擊左邊導航欄時,中間的頁面會切換,也就是改變引入的子組件。
怎么實現呢,首先,設置在該頁面index.vue中設置一個變量index,左邊導航欄每一項也對應一個index值,導航菜單綁定select函數,@select="handleSelect",@是v-on的簡寫。
handleSelect函數接收到參數,然后發射出去,再由父組件接收就可以了。
handleSelect(key, keyPath) { console.log(key, keyPath); this.changeIndex(keyPath[1]) }, changeIndex:function(key) { this.$emit("IndexChanged",key) }
this.$emit("IndexChanged",key)就是將key的值傳到一個叫IndexChanged函數中,
在index.vue綁定IndexChanged接收值,<Aside v-on:IndexChanged="change($event)"> </Aside>然后調用change函數,注意$event是固定寫法,接收的就是子頁面傳過來的key。然后就可以通過這個key改變index用來切換頁面了。
下面通過一個更加簡單直觀的例子講解一下,新建一個Test.vue:
<template> <div id="app"> </div> </template> <script> export default{ name:'Test', mounted() { }, } </script> <style> </style>
再建一個Test2.vue:
<template> </template> <script> export default { name: "Test2" } </script> <style scoped> </style>
Test.vue是父組件,Test2.vue是子組件,下面先給Test配置路由,以便在瀏覽器上可以訪問,為Test2定義模板,可以在Test中使用。
在router/index.js中添加下面代碼
import Test from "../components/Test"; Vue.use(Router) export default new Router({ mode: 'history', routes: [ { path: '/t', name: 'Test', component: Test } ] })
在main.js中,添加下面代碼:
import Test2 from "./components/Test2"; Vue.use(Test2) new Vue({ el: '#app', router, components: { App, "Test2":Test2 }, template: '<App/>' })
現在在test2頁面寫上這樣一句,
<template> <div> {{text2}} </div> </template> <script> export default { name: "Test2", data(){ return{ text2:"這是Test2頁面" } } } </script> <style scoped> </style>
在test中引入test2,同時也定義一個變量text,然后顯示在頁面上,代碼如下:
<template> <div id="app"> {{text1}} <Test2></Test2> </div> </template> <script> import Test2 from "./Test2"; export default{ name:'Test', components: {Test2}, data(){ return{ text1:"這是Test1頁面" } }, mounted() { }, } </script> <style> </style>
瀏覽器訪問http://localhost:8080/t,頁面如下:
現在要實現Test2接收Test1的值并顯示:
綁定數據用v-bind
<Test2 v-bind:text1="text1"></Test2>
傳的數據是Test頁面的text1,命名也是text1,可以不同,但接收時的名字和第一個要相同。
Test2頁面要接收數據啊,通過props接收:
props: ['text1'],
接收之后可以把它傳給text2,也可以直接在頁面顯示:
<template> <div> {{text2}} {{text1}} </div> </template> <script> export default { name: "Test2", props: ['text1'], data(){ return{ text2:"這是Test2頁面" } } } </script> <style scoped> </style>
接收到text1值了,怎么同步更改呢,需要再綁定一個函數,如下:
<Test2 v-bind:text1="text1" v-on:textChanged="change($event)"></Test2> .... methods: { change(msg){ this.text1 = msg; } },
在test2中,將值發射到textChanged就可以了
mounted() { this.$emit("textChanged","我改了text1的值") }
補充知識:在vue中使用vuex,修改state的值
1、 安裝 vuex
npm install vuex -S
2、在目錄下創建store文件
3、 在store.js編輯一個修改state的方法
然后在mian.js中全局引入
最后在組件中使用
這個的功能是運用mutations 修改state中的值
看完上述內容,你們掌握vue項目中如何實現組件之間的數據共享和修改的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。