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

vue實(shí)現(xiàn)兩個(gè)組件之間數(shù)據(jù)共享和修改操作

 更新時(shí)間:2020年11月12日 14:39:39   作者:靜幽水1  
這篇文章主要介紹了vue實(shí)現(xiàn)兩個(gè)組件之間數(shù)據(jù)共享和修改操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

我們?cè)谑褂胿ue開發(fā)過(guò)程中會(huì)遇到這樣的情況,在父組件中引入了子組件,需要將父組件的值傳到子組件中顯示,同時(shí)子組件還可以更改父組件的值。

以我目前的一個(gè)項(xiàng)目的開發(fā)為例,如下圖頁(yè)面:

在父組件中,我引入了兩個(gè)子組件,一個(gè)是左邊的導(dǎo)航欄,還有中間的一個(gè)富文本編譯器組件,當(dāng)我點(diǎn)擊左邊導(dǎo)航欄時(shí),中間的頁(yè)面會(huì)切換,也就是改變引入的子組件。

怎么實(shí)現(xiàn)呢,首先,設(shè)置在該頁(yè)面index.vue中設(shè)置一個(gè)變量index,左邊導(dǎo)航欄每一項(xiàng)也對(duì)應(yīng)一個(gè)index值,導(dǎo)航菜單綁定select函數(shù),@select="handleSelect",@是v-on的簡(jiǎn)寫。

handleSelect函數(shù)接收到參數(shù),然后發(fā)射出去,再由父組件接收就可以了。

 handleSelect(key, keyPath) {
  console.log(key, keyPath);
  this.changeIndex(keyPath[1])
  },
  changeIndex:function(key) {
  this.$emit("IndexChanged",key)
  }

this.$emit("IndexChanged",key)就是將key的值傳到一個(gè)叫IndexChanged函數(shù)中,

在index.vue綁定IndexChanged接收值,<Aside v-on:IndexChanged="change($event)"> </Aside>然后調(diào)用change函數(shù),注意$event是固定寫法,接收的就是子頁(yè)面?zhèn)鬟^(guò)來(lái)的key。然后就可以通過(guò)這個(gè)key改變index用來(lái)切換頁(yè)面了。

下面通過(guò)一個(gè)更加簡(jiǎn)單直觀的例子講解一下,新建一個(gè)Test.vue:

<template>
 <div id="app">
 
 </div>
</template>
<script>
 export default{
 name:'Test',
 mounted() {

 },
 }
</script>

<style>
</style>

再建一個(gè)Test2.vue:

<template>

</template>

<script>
 export default {
 name: "Test2"
 }
</script>

<style scoped>
</style>

Test.vue是父組件,Test2.vue是子組件,下面先給Test配置路由,以便在瀏覽器上可以訪問(wèn),為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/>'
})

現(xiàn)在在test2頁(yè)面寫上這樣一句,

<template>
<div>
 {{text2}}
</div>
</template>

<script>
 export default {
 name: "Test2",
 data(){
  return{
  text2:"這是Test2頁(yè)面"
  }
 }

 }
</script>
<style scoped>

</style>

在test中引入test2,同時(shí)也定義一個(gè)變量text,然后顯示在頁(yè)面上,代碼如下:

<template>
 <div id="app">
 {{text1}}
 <Test2></Test2>

 </div>
</template>
<script>

 import Test2 from "./Test2";
 export default{
 name:'Test',
 components: {Test2},
 data(){
  return{
  text1:"這是Test1頁(yè)面"
  }
 },
 mounted() {
 },
 }
</script>

<style>
</style>

瀏覽器訪問(wèn)http://localhost:8080/t,頁(yè)面如下:

現(xiàn)在要實(shí)現(xiàn)Test2接收Test1的值并顯示:

綁定數(shù)據(jù)用v-bind

<Test2 v-bind:text1="text1"></Test2>

傳的數(shù)據(jù)是Test頁(yè)面的text1,命名也是text1,可以不同,但接收時(shí)的名字和第一個(gè)要相同。

Test2頁(yè)面要接收數(shù)據(jù)啊,通過(guò)props接收:

props: ['text1'],

接收之后可以把它傳給text2,也可以直接在頁(yè)面顯示:

<template>
<div>
 {{text2}}
 {{text1}}
</div>
</template>

<script>
 export default {
 name: "Test2",
 props: ['text1'],
 data(){
  return{
  text2:"這是Test2頁(yè)面"
  }
 }

 }
</script>

<style scoped>
</style>

接收到text1值了,怎么同步更改呢,需要再綁定一個(gè)函數(shù),如下:

<Test2 v-bind:text1="text1" v-on:textChanged="change($event)"></Test2>
....
methods: {
  change(msg){
  this.text1 = msg;
  }

 },

在test2中,將值發(fā)射到textChanged就可以了

mounted() {
  this.$emit("textChanged","我改了text1的值")
 }

補(bǔ)充知識(shí):在vue中使用vuex,修改state的值

1、 安裝 vuex

npm install vuex -S

2、在目錄下創(chuàng)建store文件

3、 在store.js編輯一個(gè)修改state的方法

然后在mian.js中全局引入

最后在組件中使用

這個(gè)的功能是運(yùn)用mutations 修改state中的值

以上這篇vue實(shí)現(xiàn)兩個(gè)組件之間數(shù)據(jù)共享和修改操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue給對(duì)象添加屬性沒(méi)有響應(yīng)式的問(wèn)題及解決

    vue給對(duì)象添加屬性沒(méi)有響應(yīng)式的問(wèn)題及解決

    這篇文章主要介紹了vue給對(duì)象添加屬性沒(méi)有響應(yīng)式的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • 如何利用vue-cli監(jiān)測(cè)webpack打包與啟動(dòng)時(shí)長(zhǎng)

    如何利用vue-cli監(jiān)測(cè)webpack打包與啟動(dòng)時(shí)長(zhǎng)

    這篇文章主要給大家介紹了關(guān)于如何利用vue-cli監(jiān)測(cè)webpack打包與啟動(dòng)時(shí)長(zhǎng)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2022-02-02
  • vue中使用百度腦圖kityminder-core二次開發(fā)的實(shí)現(xiàn)

    vue中使用百度腦圖kityminder-core二次開發(fā)的實(shí)現(xiàn)

    這篇文章主要介紹了vue中使用百度腦圖kityminder-core二次開發(fā)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • vue指令做滾動(dòng)加載和監(jiān)聽等

    vue指令做滾動(dòng)加載和監(jiān)聽等

    這篇文章主要介紹了vue指令做滾動(dòng)加載和監(jiān)聽等,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • 解析Vue 2.5的Diff算法

    解析Vue 2.5的Diff算法

    本文將對(duì)于Vue 2.5.3版本中使用的Virtual Dom進(jìn)行分析。updataChildren是Diff算法的核心,所以本文對(duì)updataChildren進(jìn)行了圖文的分析。下面通過(guò)本文給大家分享Vue 2.5的Diff算法,需要的朋友參考下吧
    2017-11-11
  • Vue自定義可以選擇日期區(qū)間段的日歷插件

    Vue自定義可以選擇日期區(qū)間段的日歷插件

    這篇文章主要為大家詳細(xì)介紹了Vue自定義可以選擇日期區(qū)間段的日歷插件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • vue視圖不更新情況詳解

    vue視圖不更新情況詳解

    這篇文章主要介紹了vue視圖不更新情況詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • vue create、vue webpack init創(chuàng)建vue項(xiàng)目產(chǎn)生的項(xiàng)目文件的區(qū)別

    vue create、vue webpack init創(chuàng)建vue項(xiàng)目產(chǎn)生的項(xiàng)目文件的區(qū)別

    這篇文章主要介紹了vue create、vue webpack init創(chuàng)建vue項(xiàng)目產(chǎn)生的項(xiàng)目文件的區(qū)別及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • vue父組件通過(guò)props如何向子組件傳遞方法詳解

    vue父組件通過(guò)props如何向子組件傳遞方法詳解

    在Vue 中,可以使用 props 向子組件傳遞數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于vue父組件通過(guò)props如何向子組件傳遞方法的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2017-08-08
  • Vue+ElementUI?實(shí)現(xiàn)分頁(yè)功能-mysql數(shù)據(jù)

    Vue+ElementUI?實(shí)現(xiàn)分頁(yè)功能-mysql數(shù)據(jù)

    這篇文章主要介紹了Vue+ElementUI?實(shí)現(xiàn)分頁(yè)查詢-mysql數(shù)據(jù),當(dāng)數(shù)據(jù)庫(kù)中數(shù)據(jù)比較多時(shí),就每次只查詢一部分來(lái)緩解服務(wù)器和頁(yè)面壓力。這里使用elementui的?Pagination?分頁(yè)?組件,配合mysql的limit語(yǔ)句,實(shí)現(xiàn)分頁(yè)查詢mysql數(shù)據(jù),下面來(lái)看看具體實(shí)現(xiàn)過(guò)程,希望對(duì)大家學(xué)習(xí)有所幫助
    2021-12-12

最新評(píng)論