1.组件定义

1.定义组件并引用

2.父组件向子组件传值

3.子组件向父组件传值

# 组件间传值:vuex (https://www.cnblogs.com/xiaonq/p/9697921.html

1.1什么是组件

  • Html中有组件,是一段可以被复用的结构代码
  • Css中有组件,是一段可以被复用的样式
  • Js中有组件,是一段可以被复用的功能
  • Vue中也有组件,指的就是一个模块,是一个独立的,完整的(包含html,css,js等),可以直接 拿来用

1.2组件特性

  • 组件的实例化对象,跟vue实例化对象一样,因此,我们也可以将vue实例化对象看成组件
  • 组件间是独立的,因此数据要独立存储,方法要独立定义, 彼此间不能共享 。

2.父组件向子组件传值

2.1 components/Child.vue定义子组件

<template>

 <div style="color: red">

<h1>子组件内容</h1>

<p>{{data}}</p>

</div>

</template>
<script>  export default {

// 子组件要使用父组件的数据,只需要一步,在 props中接收父组件的属性

props: ['data'],  // 接收父组件给子组件定义的属性

}

</scrip>

2.2 components/Father.vue定义父组件

<template>

<div>

<h1>父组件内容</h1>

父组件显示:{{msg}}

<!--3.第三步:把父组件的某一个属性传递给子组件-->

<Child

:data='msg'

></Child>

</div>

</template>
<script>

// @指定的是src路径  import Child from '@/components/Child'   // 1.第一步:在父组件中导入子组件

export default {

// 2.第二步:父组件中注册子组件

components: {

Child   },

data() {

return {

msg: '父组件的信息'

}

},    methods: {
  } } </script>

2.3 router/index.js中注册路由

import Father from '@/components/Father'  // @修饰符指的是 src目录
export default new Router({

routes: [

{ path: '/component', name: 'Father', component: Father },]

})

2.4测试

  • 子组件中可以通过定义props属性来接收父组件的数据

3.子组件向父组件传值

3.1 components/Child.vue子组件通过触发方法, 向父组件传值

<template>

<div>{{data}}

<button @click="emitfather">调用父组件方法</button>

</div>

</template>

<script>  export default {    props: ['data'], // 接收父组件给子组件定义的属性

methods: {

emitfather() {        console.log('调用emitfather方法')

//1.子组件调用父组件方法,并传值

// $emit 触发当前实例上的事件,也可以简单的理解为触发父组件上的事件(向上冒泡)

this.$emit('changeMsg', '子组件信息修改后的data信息,传递给父组件')

}

}

} </script>

3.2 components/Father.vue给子组件添加事件及事件处理方法

<template>

<div>

父组件显示:{{msg}}    <!--4.把父组件的一个方法传递给子组件-->

<Child

:data='msg'

@changeMsg='change'

></Child>

</div>

</template>

<script>

//1.导入

import Child from '@/components/Child'

 export default {

//2.注册

components: {

Child,

},

data() {

return {

msg: '父组件的信息'

}

},

methods: {

//3.在父组件中定义一个change方法,可以在子组件中触发并传值给父组件

change(data) {

// data接收是子组件中传递的数据

// debugger

alert('调用了父组件的方法, 接收到信息:'+data)

this.msg = data  // 更新父组件的内容

}

}

}

</script>

3.3测试

点击"调用父组件方法"就会调用

day3(Vue组件)的更多相关文章

  1. vue组件

    分享出来让思路更成熟. 首先组件是 Vue.js 最强大的功能之一. 可以减少很多的工作量,提高工作效率. 编写一个可复用性的组件,虽然官网上也有.... 编写可复用性的vue组件 具备一下的几个要求 ...

  2. vue组件的配置属性

    vue组件的声明语法: Vue.component('component-name',{ template:'<p>段落{{prop1}} {{prop2}}</p>', da ...

  3. vue组件,撸第一个

    实现此例您可以学到: vue-cli的基本应用 父组件如何向子组件传递值 单文件组件如何引入scss v-on和v-for的基础应用 源码下载 一.搭建vue开发环境 更换镜像到cnpmnpm ins ...

  4. vue组件最佳实践

    看了老外的一篇关于组件开发的建议(强烈建议阅读英文原版),感觉不错翻译一下加深理解. 这篇文章制定一个统一的规则来开发你的vue程序,以至于达到一下目的. 1.让开发者和开发团队更容易发现一些事情. ...

  5. JS组件系列——又一款MVVM组件:Vue(二:构建自己的Vue组件)

    前言:转眼距离上篇 JS组件系列——又一款MVVM组件:Vue(一:30分钟搞定前端增删改查) 已有好几个月了,今天打算将它捡起来,发现好久不用,Vue相关技术点都生疏不少.经过这几个月的时间,Vue ...

  6. vue组件大集合 component

    vue组件分为全局组件.局部组件和父子组件,其中局部组件只能在el定义的范围内使用, 全局组件可以在随意地方使用,父子组件之间的传值问题等. Vue.extend 创建一个组件构造器 template ...

  7. 【Vue】详解Vue组件系统

    Vue渲染的两大基础方式 new 一个Vue的实例 这个我们一般会使用在挂载根节点这一初始化操作上: new Vue({ el: '#app' }) 注册组件并使用—— 全局注册 通过Vue.comp ...

  8. 关于vue组件的一个小结

    用vue进行开发到目前为止也有将近一年的时间了,在项目技术选型的时候隔壁组选 react的时候我们坚持使用vue作为前端的开发框架.虽然两者思想上的差异不大,但是vue的语法在代码的可读性以及后期的维 ...

  9. Vue组件基础用法

    前面的话 组件(Component)是Vue.js最强大的功能之一.组件可以扩展HTML元素,封装可重用的代码.根据项目需求,抽象出一些组件,每个组件里包含了展现.功能和样式.每个页面,根据自己所需, ...

随机推荐

  1. 转载-Eclipse导入第三方库的方法

    作者:wyf_phper 原文:https://blog.csdn.net/qq_32985981/article/details/49976193 一:导入*.jar包步骤:将下载好的jar包复制到 ...

  2. 聊聊Go代码覆盖率技术与最佳实践

    "聊点干货" 覆盖率技术基础 截止到Go1.15.2以前,关于覆盖率技术底层实现,以下知识点您应该知道: go语言采用的是插桩源码的形式,而不是待二进制执行时再去设置breakpo ...

  3. Python基础教程分享,视频教程免费下载!

    给大家分享一套我初学Python时看的一套基础教程,是视频教程,免费分享给大家,希望对正在学习Python或者打算学习Python的朋友有帮助哈~~ 废话不多说 为期92天的Python基础教程视频教 ...

  4. 阿里云函数计算 VSCode 使用,及部署 Docusaurus

    代码: https://github.com/ikuokuo/start-serverless 使用简介 产品页开通服务.使用流程,如下: 新手示例,如下: 创建函数 阿里云提供了如下几种方式创建函数 ...

  5. http 结构初始化

    简要而说:accept 到连接后 根据fd 构建一个connection  由于是 http : 重新封装为http-connection:同时设置fd的读回调: 回调函数根据是否是https/htt ...

  6. 利用c++ std::getline实现split

    getline reads characters from an input stream and places them into a string: getline从输入流中读取字符, 并把它们转 ...

  7. python之路《模块》

    1.time模块 FUNCTIONS asctime(...) asctime([tuple]) -> string Convert a time tuple to a string, e.g. ...

  8. linux中/etc/passwd和/etc/shadow文件说明

    /etc/passwd是用来存储登陆用户信息: [root@localhost test]# cat /etc/passwd root:x:0:0:root:/root:/bin/bash bin:x ...

  9. ceph bluestore的db分区应该预留多大的空间

    前言 关于bluestore的db应该预留多少空间,网上有很多资料 如果采用默认的 write_buffer_size=268435456 大小的话 那么几个rocksdb的数据等级是 L0: in ...

  10. Python面试题_初级版

    1.如何在一个函数内部修改全局变量 a=5 def fn(): a=4 fn() print(a) # 5 #在一个函数内部修改全局变量 a=5 def fn(): global a a=4 fn() ...