1.前言

  • 本节讲述组件之间如何进行数据交互

2.props属性与非 prop 的属性

父组件通过属性绑定的形式传值给子组件,这种传值分2种

类别 含义 说明
props 子组件本身已经通过props定义过,有明确的用途 传递的数据如何渲染取决于代码编写
非 prop 未经过props定义,无法预知其用途 直接渲染到根标签中

3.props传递与接收

  • 在父组件中把要传递的数据通过属性的形式绑定到子组件标签上,属性名不却分大小写,支持驼峰法命名
<child-component :title="title" :list="list"></child-component>
  • 子组件通过props字段进行定义接收(数据类型和默认值)
var childComponent = {
data(){
return {}
},
props:{
title:{
//数据类型包括: String,Number,Array,Object,Boolean等
type:String,
default:""
},
list:{
type:Array,
//默认值是数字或者对象,需要定义function进行返回
default:function(){
return []
}
}
}
}
  • 对于布尔值,传递属性却没有值的情况,相当于传入了true
<!-- 包含该 prop 没有值的情况在内,都意味着 `true`。-->
<blog-post is-published></blog-post>
  • 单项数据流:父组件数据发生改变,会触发子组件视图更新,而反过来就不会(引用数据类型除外)

4.自定义事件

  • 子组件可以在适当的时机调用$emit()方法抛出一个事件给父组件
  • 自定义事件的名称必须一致,区分大小写,不支持驼峰法命名
this.$emit('eventName',参数)
  • 父组件在子组件标签中定义相关的事件回调,依次来响应子组件抛出的事件,还可以通过$on()方法来监听子组件事件
//标签语法
<child @eventName="showMsg"></Child>
//js语法
<child ref="child"></Child> //通过ref标识找到子组件,并为其添加子定义事件
this.$refs.child.$on('eventName',this.showMsg)

5.sync 修饰符

  • props属性是单向数据流,如果需要做双向数据绑定,除了可以使用v-model指令,还可以使用sync修饰符
  • sync修饰符和v-model修饰符本质上都是通过自定义事件同步修改了父组件的值,相当于省略了父组件定义自定义事件回调的部分
  • v-model通过model字段来定义事件名称,而sync 修饰符的事件名称的格式是固定的,即:update:prop属性名
  • 实例:定义一个支持sync 修饰符的组件(关键在于合适的时机触发update:xxx事件)
var textDocument = {
template:"<input type='text' :value='value' @input='onInput'></input>",
data(){
return { }
},
props:{
value:{
type:String,
default:""
}
},
methods:{
onInput(e){
//当前输入框的值
console.log(e.target.value)
//触发自定义事件
this.$emit('update:value',e.target.value)
}
}
}

6.直接访问父/子组件

  • 父组件通过this.$refs.xxx来访问子组件,前提是在子组件标签中使用ref属性进行声明
//子组件标签中使用ref属性进行声明
<Child ref="child" />
//访问子组件的数据
this.$refs.child.title
  • 子组件通过this.$parent来访问父组件
this.$parent.sayHello()

7.传递HTML内容

  • props只能传递数据给子组件,如果要传递html内容,要使用插槽,具体见Vue.js slot插槽

8.非 prop 的属性

  • 父组件挂载非 prop 的属性到子组件标签中,且子组件只有一个根标签时,这个属性值会被合并到子组件根标签中(2.x/3.x都适用)
//子组件HTML模版
<template>
<div class="box">子组件</div>
</template>
//父组件传递 非 prop 的属性
<child class="text-center" data-index="1"></child>
//渲染结果
<div class="box text-center" data-index="1">子组件</div>
  • 如果子组件有多个根标签(vue2.x不支持多个根标签),默认这些非 prop 的属性不会挂载到子组件的标签中,他们被封装到$sttrs这个对象中,可以通过他将非 prop 的属性绑定到目标标签中
//子组件HTML模版
<template>
<div class="box" :class="$attrs.class">子组件根标签1</div>
<div class="box" :data-index="$attrs['data-index']">子组件根标签2</div>
</template>
//渲染结果
<div class="box text-center">子组件根标签1</div>
<div class="box" data-index="1">子组件根标签2</div>

9.依赖注入

  • 可以把依赖注入看作一部分“大范围有效的 prop”,通过他可以让所有后代组件访问父组件的属性或者方案
//父组件进行声明
provide: function () {
return {
title: "感冒"
}
}
//后代组件进行接收
inject: ['title']
  • 依赖注入所提供的 property 是非响应式的

Vue.js 组件数据交互的更多相关文章

  1. vue.js组件化开发实践

    前言 公司目前制作一个H5活动,特别是有一定统一结构的活动,都要码一个重复的轮子.后来接到一个基于模板的活动设计系统的需求,便有了下面的内容.借油开车. 组件化 需求一到,接就是怎么实现,技术选型自然 ...

  2. VUE.JS组件化

    VUE.JS组件化 前言 公司目前制作一个H5活动,特别是有一定统一结构的活动,都要码一个重复的轮子.后来接到一个基于模板的活动设计系统的需求,便有了下面的内容.借油开车. 组件化 需求一到,接就是怎 ...

  3. Vue.js 组件的三个 API:prop、event、slot

    组件的构成 一个再复杂的组件,都是由三部分组成的:prop.event.slot,它们构成了 Vue.js 组件的 API.如果你开发的是一个通用组件,那一定要事先设计好这三部分,因为组件一旦发布,后 ...

  4. 如何理解vue.js组件的作用域是独立的

    vue.js组件的作用域是独立,可以从以下三个方面理解: 1.父组件模板在父组件作用域内编译,父组件模板的数据用父组件内data数据:2.子组件模板在子组件作用域内编译,子组件模板的数据用子组件内da ...

  5. 浅尝Vue.js组件(一)

    本篇目录: 组件名 组件注册 全局注册 基础组件的自动化全局注册 局部注册 在模块系统中局部注册 Prop 单向数据流 Prop验证 类型检查 非Prop特性 替换/合并已有的特性 禁用特性继承 自定 ...

  6. Vue.js 组件编码规范

    本规范提供了一种统一的编码规范来编写 Vue.js 代码.这使得代码具有如下的特性: 其它开发者或是团队成员更容易阅读和理解. IDEs 更容易理解代码,从而提供高亮.格式化等辅助功能 更容易使用现有 ...

  7. Vue.js组件的重要选项

    Vue.js组件的重要选项 实例化Vue对象一些很重要的选项,Vue的所有数据都是放在data里面的,Vue的参数是个对象,对象里面的字段叫做data,data里面也是对象,data也可以写作是thi ...

  8. Vue框架(二)——Vue指令(v-once指令、v-cloak指令、条件指令、v-pre指令、循环指令)、todolist案例、Vue实例(计算、监听)、组件、组件数据交互

    Vue指令 1.v-once指令  单独使用,限制的标签内容一旦赋值,便不可被动更改(如果是输入框,可以主动修改) <!DOCTYPE html> <html lang=" ...

  9. vue.js 组件之间传递数据

    前言 组件是 vue.js 最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用.如何传递数据也成了组件的重要知识点之一. 组件 组件与组件之间,还存在着不同的关 ...

  10. vue.js组件之j间的通讯一 子组件接受父祖件数据

    Vue2.0的三种常用传值方式.父传子.子传父.非父子组件传值 在Vue的框架开发的项目过程中,经常会用到组件来管理不同的功能,有一些公共的组件会被提取出来.这时必然会产生一些疑问和需求?比如一个组件 ...

随机推荐

  1. LinkedHashMap原理详解—从LRU缓存机制说起

    写在前面 从一道Leetcode题目说起 首先,来看一下Leetcode里面的一道经典题目:146.LRU缓存机制,题目描述如下: 请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结 ...

  2. Rounding

    前言 以前写过一篇关于 Rouding 的 decimal, double, float, 但有点杂乱, 这篇做一个整理. Why need rouding? 除法会诞生小数. 甚至会诞生无限小数 ( ...

  3. Servlet——执行流程、生命周期、方法介绍、体系结构

    执行流程    生命周期 对象的生命周期是指一个对象从被创建到被销毁的整个过程 Servlet运行在Servlet容器(web服务器)中,其生命周期由容器管理,分为四个阶段:     1. 加载和实例 ...

  4. .Net 依赖注入深入探索,做一个DI拓展,实现一个简易灵活的 自动依赖注入框架

    一.依赖注入相关知识 1.1.依赖注入的原理和优点 依赖注入(DI),是IOC控制反转思想 的实现.由一个DI容器,去统一管理所有的服务生命周期,服务的创建.销毁.获取,都是由DI容器去处理的. 依赖 ...

  5. vue 赶鸭子上架入门笔记(一) 安装开发环境

    准备接手一个 vue 的前端项目,从零开始学习 vue.目标不高大上,能看得懂代码,能进行简单的修改,改完能打包和部署. 首先解决 vue 开发环境的准备.访问 Node.js 官方网站,下载适合你操 ...

  6. Linux 进程调度之schdule主调度器

    考虑到文章篇幅,在这里我只讨论普通进程,其调度算法采用的是CFS(完全公平)调度算法. 至于CFS调度算法的实现后面后专门写一篇文章,这里只要记住调度时选择一个优先级最高的任务执行 一.调度单位简介 ...

  7. Kubernetes的RBAC权限控制

    role和roleBinding Role资源定义了哪些操作可以在哪些资源上执行.也可以直接控制访问的url的权限,下面的cluster也是这样. 查询所有service的demo: apiVersi ...

  8. 云原生周刊:Dapr v1.11 发布

    开源项目推荐 Kamaji Kamaji 可以大规模地部署和运行 Kubernetes 控制平面,而只需承担一小部分操作负担.Kamaji 的特别之处在于,控制平面组件是在一个单一的 pod 中运行, ...

  9. 如何使用 GoGoCode 一键 Vue2 转换 Vue3

    前言 从今年年初开始,项目开始升级优化,将之前的 Vue2 旧版本整体升级到 Vue3 版本.在重写了几个 Vue 文件后,我发现做的都是一些机械性的工作,效率低且重复性大.于是就试着搜索了一下有没有 ...

  10. vue axios的使用及操作

    引入axios  并设置原型 Vue.prototype.$axios = axios;   在其他地方就可以this.$axios使用了   let param = _this.$qs.string ...