[js高手之路]Vue2.0基于vue-cli+webpack父子组件通信教程

在git命令行下,执行以下命令完成环境的搭建:

1,npm install --global vue-cli  安装vue命令行工具

2,vue init webpack vue-demo   使用vue命令生成一个webpack项目,项目名称为vue-demo

3,cd vue-demo 切入项目

4,npm install安装package.json中的所有依赖包

5,npm run dev运行项目

一、父组件向子组件传递数据

然后删除默认的Hello.vue组件,把App.vue整理成以下样子:

 1 <template>
 2   <div id="app">
 3   这是一个空的app
 4   </div>
 5 </template>
 6
 7 <script>
 8   export default {
 9     name : ‘app‘
10   }
11 </script>
12
13 <style>
14
15 </style>

把router下面index.js文件修改如下:

 1 import Vue from ‘vue‘
 2 import Router from ‘vue-router‘
 3
 4 Vue.use(Router)
 5
 6 export default new Router({
 7   routes: [
 8     {
 9       path: ‘/‘,
10     }
11   ]
12 })

1、在components目录下创建一个子组件Child.vue

代码如下:

 1 <template>
 2     <div>
 3         <h3>这是子组件</h3>
 4         <p>{{content}}</p>
 5     </div>
 6 </template>
 7 <script>
 8 export default {
 9     props : [‘content‘]
10 }
11 </script>

2、把App.vue的代码修改如下:

 1 <template>
 2   <div id="app">
 3     <child :content="msg"></child>
 4   </div>
 5 </template>
 6
 7 <script>
 8   import child from ‘./components/Child.vue‘;
 9   export default {
10     name : ‘app‘,
11     data(){
12       return {
13         ‘msg‘ : ‘这是来自父组件的问候‘
14       }
15     },
16     components : {
17       child
18     }
19   }
20 </script>

这样就完成了父组件通过props属性向子组件传递数据

也可以用v-bind绑定属性

<template>
  <div id="app">
    <child :content="msg"></child>
    <child v-bind:content="msg"></child>
  </div>
</template>

小结:

  • 子组件在props中创建一个属性,用以接收父组件传过来的值
  • 父组件中调用子组件
  • 在子组件标签中绑定子组件props中创建的属性
  • 把需要传给子组件的值赋给该属性,如我们上文中父组件的msg

二、子组件向父组件传递数据

1,把Child.vue修改如下:

 1 <template>
 2     <div>
 3         <h3>这是子组件</h3>
 4         <p>{{content}}</p>
 5         <p>
 6             <input type="button" value="告诉父王一个消息" v-on:click="send">
 7         </p>
 8     </div>
 9 </template>
10 <script>
11 export default {
12     props : [‘content‘],
13     methods : {
14         send(){
15             this.$emit( ‘ParentRecEv‘, "父王,孩儿正在跟ghostwu学习vue2.0" )
16         }
17     }
18 }
19 </script>

子组件通过$emit发送一个自定义的事件ParentRecEv, 后面参数是内容

2,App.vue修改如下

 1 <template>
 2   <div id="app">
 3     <child :content="msg"></child>
 4     <child v-bind:content="msg" v-on:ParentRecEv="showMsg"></child>
 5     <p>{{data}}</p>
 6   </div>
 7 </template>
 8
 9 <script>
10   import child from ‘./components/Child.vue‘;
11   export default {
12     name : ‘app‘,
13     data(){
14       return {
15         ‘msg‘ : ‘这是来自父组件的问候‘,
16         data : ‘‘
17       }
18     },
19     methods : {
20       showMsg( msg ){
21         this.data = msg;
22       }
23     },
24     components : {
25       child
26     }
27   }
28 </script>

在第二个子组件监听事件ParentRecEv,当子组件点击按钮就会触发这个自定义事件,然后触发showMsg函数,就能收到子组件传递的数据,没有绑定自定义事件是不能收到子组件发送的信息的.

小结:

  • 子组件中通过$emit触发一个自定义事件
  • 将需要传的值作为$emit的第二个参数,该值会被父组件的方法接收到
  • 在父组件中调用子组件并在子组件标签上绑定发送的自定义事件

他们的共同点就是有桥梁,子向父的桥梁是自定义事件$emit,父向子的桥梁是props中的属性. 这就是他们之间传递数据的关键

时间: 2024-08-05 15:24:27

[js高手之路]Vue2.0基于vue-cli+webpack父子组件通信教程的相关文章

vue学习之父子组件通信两种方法

初学vue,最常用及实用的就是父子组件之间的通信了,在此记录一点自己的学习过程 方法一:props及$emit 父组件中先引入子组件,然后components里面注册组件,然后template里调用,调用的时候通过v-bind传递值给子组件,v-on监听子组件$emit传递过来的值 子组件中先用props接收父组件的传值,注意子组件中不可直接修改父组件的传值,可通过watch监听来赋值,通过$emit来传递值给父组件 方法二:ref 父组件传值props方法不变,父组件可通过使用ref来调用子组

[js高手之路]Node.js实现简易的爬虫-抓取博客所有文章列表信息

抓取目标:就是我自己的博客:http://www.cnblogs.com/ghostwu/ 需要实现的功能: 抓取博客所有的文章标题,超链接,文章摘要,发布时间 需要用到的库: node.js自带的http库 第三方库:cheerio,这个库就是用来处理dom节点的,他的用法几乎跟jquery用法一模一样,所以有了这个利器,写一个爬虫就非常简单 准备工作: 1,npm init --yes 初始化package.json 2,安装cheerio:npm install cheerio --sav

Vue2.0笔记——Vue实例

Vue实例 每个 Vue 应用都是通过用 Vue 函数创建一个新的 Vue 实例开始的: var vm = new Vue({ // 选项 }) 当创建一个 Vue 实例时,你可以传入一个选项对象,就如前面所提到的如:data,methods,computed,watch等等.一个 Vue 应用由一个通过 new Vue 创建的根 Vue 实例,以及可选的嵌套的.可复用的组件树组成.举个例子,一个 todo 应用的组件树可以是这样的: 根实例Root └─ TodoList ├─ TodoIte

Vue2.0总结———vue使用过程常见的一些问题

Vue目前的的开发模式主要有两种: 1.直接页面级的开发,script直接引入Vue 2.工程性开发,webpack+loader或者直接使用脚手架工具Vue-cli,里面的文件都配置好了 webpack可以进行配置,配置多文件入口,进行多页面开发 第二种Vue开发,结合webpack打包完文件会很大,怎么解决这个问题? 1.webpack代码拆分:code-spliting 2.提取公共(如提取css,js) 3.预渲染:使用prerender-spa-plugin插件 4.后台----开启压

[js高手之路]Node.js+jade+express+mongodb+mongoose+promise实现todolist

promise主要是用来解决异步回调问题,其实还有好几种比promise更好的方案,后面再说,这节,我们先用promise来改造下,我以前写的一篇文章[js高手之路]javascript腾讯面试题学习封装一个简易的异步队列 中的一道面试题( 页面上有一个按钮,一个ul,点击按钮的时候,每隔1秒钟向ul的后面追加一个li, 一共追加10个,li的内容从0开始技术( 0, 1, 2, ....9 ) ). promise的小实例: 1 function next1(){ 2 return new P

[js高手之路]深入浅出webpack教程系列9-打包图片(file-loader)用法

[js高手之路]深入浅出webpack教程系列索引目录: [js高手之路]深入浅出webpack教程系列1-安装与基本打包用法和命令参数 [js高手之路]深入浅出webpack教程系列2-配置文件webpack.config.js详解(上) [js高手之路]深入浅出webpack教程系列3-配置文件webpack.config.js详解(下) [js高手之路]深入浅出webpack教程系列4-插件使用之html-webpack-plugin配置(上) [js高手之路]深入浅出webpack教程系

[js高手之路]Node.js+jade+mongoose实战todolist(分页,ajax编辑,删除)

该系列文章索引: [js高手之路]node js系列课程-创建简易web服务器与文件读写 [js高手之路]node js系列课程-图解express+supervisor+ejs用法 [js高手之路]Node.js实现简易的爬虫-抓取博客所有文章列表信息 [js高手之路]Node.js模板引擎教程-jade速学与实战1-基本用法 [js高手之路]Node.js模板引擎教程-jade速学与实战2-流程控制,转义与非转义 [js高手之路]Node.js模板引擎教程-jade速学与实战3-mixin

[js高手之路] es6系列教程 - promise常见用法详解(resolve,reject,catch,then,all,race)

关于promise我在之前的文章已经应用过好几次,如[js高手之路]Node.js+jade+express+mongodb+mongoose+promise实现todolist,本文就来讲解下promise的常见用法. 为什么会有promise,他的作用是什么? promise主要是为了解决js中多个异步回调难以维护和控制的问题. 什么是promise? 从图中,我们可以看出,Promise是一个函数,这个函数上有在项目中常用的静态方法:all, race, reject,resolve等,原

[js高手之路] es6系列教程 - 迭代器与生成器详解

什么是迭代器? 迭代器是一种特殊对象,这种对象具有以下特点: 1,所有对象都有一个next方法 2,每次调用next方法,都会返回一个对象,该对象包含两个属性,一个是value, 表示下一个将要返回的值.另一个是done,他是一个布尔值,用来表示该迭代器是否还有数据可以返回. 3,迭代器还会保存一个内部指针指向当前集合中的值 设计模式中有个迭代模式,跟迭代器是差不多的,我之前有写过2篇文章关于迭代模式: [js高手之路] 设计模式系列课程 - 迭代器(1) [js高手之路] 设计模式系列课程 -