电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

vue實現兩個組件之間數據共享和修改操作

瀏覽:95日期:2022-10-30 15:04:41

我們在使用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,頁面如下:

vue實現兩個組件之間數據共享和修改操作

現在要實現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>

vue實現兩個組件之間數據共享和修改操作

接收到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實現兩個組件之間數據共享和修改操作

補充知識:在vue中使用vuex,修改state的值

1、 安裝 vuex

npm install vuex -S

2、在目錄下創建store文件

vue實現兩個組件之間數據共享和修改操作

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

vue實現兩個組件之間數據共享和修改操作

然后在mian.js中全局引入

vue實現兩個組件之間數據共享和修改操作

最后在組件中使用

vue實現兩個組件之間數據共享和修改操作

這個的功能是運用mutations 修改state中的值

以上這篇vue實現兩個組件之間數據共享和修改操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 课件导航网_ppt课件_课件模板_课件下载_最新课件资源分享发布平台 | 风淋室生产厂家报价_传递窗|送风口|臭氧机|FFU-山东盛之源净化设备 | 深圳办公室装修-写字楼装修设计-深圳标榜装饰公司 | 高柔性拖链电缆_卷筒电缆_耐磨耐折聚氨酯电缆-玖泰特种电缆 | LZ-373测厚仪-华瑞VOC气体检测仪-个人有毒气体检测仪-厂家-深圳市深博瑞仪器仪表有限公司 | RV减速机-蜗轮蜗杆减速机-洗车机减速机-减速机厂家-艾思捷 | 洛阳网站建设_洛阳网站优化_网站建设平台_洛阳香河网络科技有限公司 | 昆明挖掘机修理厂_挖掘机翻新再制造-昆明聚力工程机械维修有限公司 | 高精度-恒温冷水机-螺杆式冰水机-蒸发冷冷水机-北京蓝海神骏科技有限公司 | 引领中高档酒店加盟_含舍·美素酒店品牌官网 | 破碎机锤头_耐磨锤头_合金锤头-鼎成机械一站式耐磨铸件定制服务 微型驱动系统解决方案-深圳市兆威机电股份有限公司 | 石家庄律师_石家庄刑事辩护律师_石家庄取保候审-河北万垚律师事务所 | 莱州网络公司|莱州网站建设|莱州网站优化|莱州阿里巴巴-莱州唯佳网络科技有限公司 | 上海璟文空运首页_一级航空货运代理公司_机场快递当日达 | 精密光学实验平台-红外粉末压片机模具-天津博君 | 粉末包装机-给袋式包装机-全自动包装机-颗粒-液体-食品-酱腌菜包装机生产线【润立机械】 | 美国查特CHART MVE液氮罐_查特杜瓦瓶_制造全球品质液氮罐 | 鑫铭东办公家具一站式定制采购-深圳办公家具厂家直销 | 定制奶茶纸杯_定制豆浆杯_广东纸杯厂_[绿保佳]一家专业生产纸杯碗的厂家 | 鹤壁创新仪器公司-全自动量热仪,定硫仪,煤炭测硫仪,灰熔点测定仪,快速自动测氢仪,工业分析仪,煤质化验仪器 | 宁夏档案密集柜,智能密集柜,电动手摇密集柜-盛隆柜业宁夏档案密集柜厂家 | 喷漆房_废气处理设备-湖北天地鑫环保设备有限公司 | 广州工业氧气-工业氩气-工业氮气-二氧化碳-广州市番禺区得力气体经营部 | 上海皓越真空设备有限公司官网-真空炉-真空热压烧结炉-sps放电等离子烧结炉 | 专业生物有机肥造粒机,粉状有机肥生产线,槽式翻堆机厂家-郑州华之强重工科技有限公司 | 厂房出租_厂房出售_产业园区招商_工业地产&nbsp;-&nbsp;中工招商网 | 压缩空气检测_气体_水质找上海京工-服务专业、价格合理 | 辐射色度计-字符亮度测试-反射式膜厚仪-苏州瑞格谱光电科技有限公司 | 滚塑PE壳体-PE塑料浮球-警示PE浮筒-宁波君益塑业有限公司 | 混合反应量热仪-高温高压量热仪-微机差热分析仪DTA|凯璞百科 | 罗茨真空机组,立式无油往复真空泵,2BV水环真空泵-力侨真空科技 | 福建省教师资格证-福建教师资格证考试网 | 泰兴市热钻机械有限公司-热熔钻孔机-数控热熔钻-热熔钻孔攻牙一体机 | 苏州注册公司_苏州代理记账_苏州工商注册_苏州代办公司-恒佳财税 | 礼仪庆典公司,礼仪策划公司,庆典公司,演出公司,演艺公司,年会酒会,生日寿宴,动工仪式,开工仪式,奠基典礼,商务会议,竣工落成,乔迁揭牌,签约启动-东莞市开门红文化传媒有限公司 | 实验室装修_实验室设计_实验室规划设计- 上海广建净化工程公司 | 上海单片机培训|重庆曙海培训分支机构—CortexM3+uC/OS培训班,北京linux培训,Windows驱动开发培训|上海IC版图设计,西安linux培训,北京汽车电子EMC培训,ARM培训,MTK培训,Android培训 | 冲锋衣滑雪服厂家-冲锋衣定制工厂-滑雪服加工厂-广东睿牛户外(S-GERT) | 电脑知识|软件|系统|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网 | 真空粉体取样阀,电动楔式闸阀,电动针型阀-耐苛尔(上海)自动化仪表有限公司 | 亿诺千企网-企业核心产品贸易 |