VueCli标准化工程中的组件通信操作

1.使用scoped解决样式冲突:

默认情况下:写在组件中的样式会全局生效,因此很容易造成多个组件之间的样式冲突问题;

(1)全局样式:默认情况下无论是否是全局组件,样式都会加载到全局;

(2)局部样式:使用scoped属性,可以让样式只作用于当前组件,包括全局组件;

scoped的原理是:给当前组件的所有元素,都添加上一个自定义属性data-v-hash值;

css选择器后面,被自动处理,添加上了属性选择器;

2.data函数的定义:

与之前传统的HTML形式开发不同,在VueCli中对于data可能会出现父组件引用多次相同子组件的情况,这种情况就会出现无法实现每次子组件的数据独立性,修改其中的一个数据,其他子组件也会被影响,因此我们可以使用data函数的形式,每使用一次子组件就创建一个新对象,以实现数据的独立性;

3.组件间的通信:

3.1父组件与子组件之间的通信:

父子组件通信的流程:

父组件通过props将组件传递给子组件,子组件通过$emit通知父组件修改更新;

父组件传值给子组件时在第二步中 :属性名="值"属性名可以是HTML原生属性,也可以自己取名:

子组件通过$emit()方法提醒父组件修改数据

使用props还可以传递任意数量任意类型的数据,用props进行批量传值:

props校验:用来校验传递过来的数据满不满足要求,如果不满足会报错:

props类型校验

可以校验数据类型,非空校验,默认值设置,以及自定义校验

props和data的区别:

二者都可以用来定义数据,区别在于props是接收的外部的数据不能随便更改,如果需要修改需要通知父组件进行修改,而data是自己的数据可以随意修改;

4.非父子通信--eventBus事件总线:

实现步骤:

(1)创建一个都能访问到的事件总线(空的Vue实例)

复制代码
import Vue from 'vue'
const Bus  =  new Vue()
export default Bus

(2)A(组件),接收方监听Bus实例的事件:

(3)B组件(发送方),触发Bus实例的事件

(4)在App.vue根组件中进行定义

5.组件跨层级共享数据--Provide&Inject

实现步骤:

(1)祖先组件provide提供数据:

(2)后备组件inject取值使用:

这里如果祖先组件修改非响应式数据(非对象),后辈组件是不会接收到的;

6.v-model本质上是一个语法糖,代表了:value和@input的双向绑定

我们将表单封装在组件里面。通过前面我们知道,数据是封装在父组件的,如果表单定义在子组件里面,如何实现表单和数据的双向绑定?这个时候不能直接使用v-model。因为v-model的使用前提是视图和数据都在同一个组件里面才可以。

这里可以使用v-model简化父组件代码:

子组件中:props通过value吸收,事件触发input

父组件中:v-model给组件直接绑定数据(:value="" @input="")

7.sync属性:

可以实现子组件和父组件数据的双向绑定

特点:prop属性名,可以自定义,非固定为value

本质:就是:属性名和@update:属性名合写

8.ref和$refs

作用:使用ref和$refs可以用于获取dom元素,或组件实例;

特点:查找范围在当前组件内;

操作dom元素

我们还可以通过ref和$refs操作组件实例。我们通常在组件内部会封装一些函数。这个时候我们可以在父组件内部去获取这些子组件的实例,然后基于子组件的实例去调用子组件内部封装的函数。

8.使用$nextTick实现VueDOM元素的异步更新:

在更新完DOM数据后,需要一段时间来重新渲染DOM元素,因此在修改完DOM后向进行进一步的更新需要保证异步实现,也就是必须先让DOM更新完并重新渲染完再去操作;

语法如下:

相关推荐
weixin_443478512 小时前
Flutter第三方常用组件包学习之状态管理
javascript·学习·flutter
Yiyi_Coding2 小时前
Proxy详解
java·前端·javascript
ySq0REx012 小时前
.NET 10 & C# 14 New Features 新增功能介绍-.NET CLI工具改进
开发语言·c#·.net
a1117762 小时前
PreTeXt 开源推荐(应用demo)
前端·开源·html
Howrun7772 小时前
C++ 项目测试全指南:从 0 基础到落地实操
开发语言·c++·log4j
小灰灰搞电子2 小时前
Qt UI 线程详解-阻塞与解决方案
开发语言·qt·ui
追光的蜗牛丿2 小时前
C++传递参数时什么情况下传递引用
开发语言·javascript·c++
Pocker_Spades_A2 小时前
Python快速入门专业版(五十六)——爬虫会话管理:Cookie与Session原理及实战(保持登录状态)
开发语言·爬虫·python
MwEUwQ3Gx2 小时前
深入理解 Java Deque 的设计哲学
java·开发语言·python