vue父子组件通信

  首先认识一下vue的目录结构。vue是一个组件化开发的语言,组件之间是有父子关系的,还有一种关系叫全局组件和局部组件。

   App.vue可以被认为是所有组件的父组件,它也是整个页面的入口文件,是之前提到过的body。其它组件被放在src->components里面,文件后缀都是.vue。HelloWorld.vue就是一个组件,初始化的模板为我们提供了一种方法,实现了组件的挂载:路由。

图1-1 文件目录结构

问题:初始化的模板是如何将HelloWorld.vue挂载到app.vue的?

            <router-view/>

图1-2 app.vue

 问题:<router-view/>路由指向哪里?在哪里定义的指向?

          在router目录下的index.js文件中定义了路由。

图1-3 router的定义

          首先index.js先import vue-router,保证在此js文件可以识别vue-router的语法,然后导入了HelloWorld.vue这个组件。Vue.use(Router)代表使用路由。

          export default new Router初始化了一个默认的路由,在Vue中,path:'/' 代表了最顶层的路由,也就是所有组件的父组件app.vue调用的路由路径,可以看到路由指向了HelloWorld组件。

          图1-2 app.vue中,<router-view/>的作用就体现了出来,将<div/>显示的内容指向了路由,路由文件index.js将路由指向了HelloWorld.vue,这样就完成了组件的挂载。

图1-4 index.js文件

        了解了组件是如何挂载的,接下来了解组件是如何通信的。

        一个完整的vue项目组件之间的关系是十分复杂的,会层层嵌套组件。所以在原则上,vue是不允许数据双向流动的,意思就是只允许父组件的数据传递给子组件,子组件的数据不允许传递到父组件,这样保证了数据的单向流动性。

        凡事都有例外,如果真的需要子组件向父组件传递数据,需要子组件触发Emit Event(发出事件)。

图2-1 vue组件通信示意图

组件内部通信Demo:实现购物车商品加减按钮。

①新建一个组件Counter.vue.

图2-2 Counter.vue

②初始化两个button,“+” 和 “-” ,中间为显示的数字。

 ③初始化两个method:increment和decrement来实现num的“加”和“减”,并初始化num的数值为0。

  ④将method绑定在button上,并用“点击”事件触发。

  ⑤让HelloWorld.vue加载Counter.vue

   打开HelloWorld.vue。用import Counter from './Counter'来加载Counter组件。" ./ " 代表同一级目录。

    ⑥在Script中加载components.

      ⑦调用组件Counter.然后看一下效果~!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容

  • 1.子组件获取父组件data 子组件为bbb父组件为aaabbb想要获取aaa里的msg,msg1 父组件调用子组...
    玄月府的小妖在debug阅读 843评论 0 4
  • 在使用vue的过程中,如果需要进行父子组件间的通信,通过查阅官方文档我们可以了解到只需要在子组件要显式地用 pro...
    fisher_zh阅读 420评论 0 1
  • Vue父子组件通信 Web中的组件其实就是页面组成的一部分。 那组件之间的通信该怎么办?这是个重点(必须掌握),同...
    程序员之路阅读 652评论 0 2
  • 许久没有联系的表姐,前些天突然给我打电话了,原因很简单,后悔当初没听我的话,现在落得人财两空。 那天是深夜,我没有...
    沁蘭阅读 5,174评论 110 120
  • 融资计 划 书 一、项目介绍 项目名称:藏龙湖生态特供农业 园 经营范围:农业观光休闲体验、特供养殖、特供种植、餐...
    304477992eab阅读 285评论 0 1