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更新完并重新渲染完再去操作;

语法如下:

相关推荐
沐土Arvin14 分钟前
港澳台行政区域json
前端
skywalk816321 分钟前
言知项目后续方向建议
开发语言·学习·编程
程序员鱼皮35 分钟前
我花 300 块,让 Claude Fable 5 开发桌面 APP,值么?
前端
William_Xu40 分钟前
JavaScript 并发控制
前端
拾年27540 分钟前
从零手写 Ajax:用原生 XHR 搭建前后端交互全流程
前端·javascript·ajax
光影少年42 分钟前
懒加载与分包:React.lazy + Suspense
前端·react.js·掘金·金石计划
拉勾科研工作室1 小时前
区块链工程毕业论文题目【249个】
开发语言·javascript
小林ixn1 小时前
你以为你懂 + 号?看完这篇 Bun + TS 实战,才发现以前全写错了
前端·javascript·typescript
namexingyun1 小时前
开源前端生态如何成为 AI UI 生成的“燃料“:shadcn/ui、Tailwind CSS、Storybook 技术价值全解剖
java·前端·人工智能·python·ui·开源·ai编程
Zyed1 小时前
[STM32]Day15读写FLASH+读取ID
前端·stm32·性能优化