Vue | Vue.js 组件化 知识拓展(一)

简介: Vue | Vue.js 组件化 知识拓展(一)

一、组件的生命周期

认识生命周期

什么是生命周期呢?


       生物学上,生物生命周期指的是一个生物体在生命开始到结束 周而复始所历经的一系列变化过程;


       每个组件都可能会经历从 创建 挂载 更新 卸载 等一系列的过程


       在这个过程的某一个阶段 我们可能会想要 添加一些属于自己的代码逻辑(如组件创建后请求服务器数据)


       但是我们 如何可以知道目前组件正在哪一个过程? Vue给我们提供了 组件的生命周期函数


命周期函数:


       生命周期函数是 一些钩子函数(回调函数),在 某个时间会被Vue源码内部进行回调


       通过对生命周期函数的回调,我们可以知道 目前组件正在经历什么阶段


       我们就可以在 该生命周期中编写属于自己的逻辑代码了

生命周期的流程


36c72a99113a43c2a2e9b3210a37944e.jpg

a6dba969f8734004a832e5107ace026d.png

生命周期的过程分析

App/Home/Banner/ShowMessage


       beforeCreate


1.创建组件实例


       created(重要: 1 发送网络请求 2事件监听 3 this.$watch())


2.template模版编译


       beforeMount


3.挂载到虚拟DOM -> 虚拟DOM -> 真实的DOM -> 用户界面看到 div


       mounted(重要:元素已经被挂载 获取DOM  使用DOM)


4 数据更新 message发生改变


       beforeUpdate


根据最新数据生成新的VNode 生成新的虚拟DOM  -> 真实的DOM


       Updated


5 不再使用 v-if="fasle"


       beforeUnmount


       将之前挂载在虚拟DOM中VNode从虚拟DOM中移除


       unmounted(相对重要: 进行回收操作(取消事件监听))


最后 将组建实例销毁掉

二、组件中的ref引用

$refs的使用

我们在组件中想要直接获取到元素对象或子组件实例:


       在Vue开发中我们是 不推荐进行原生DOM操作


       这个时候 我们可以给元素或者组件绑定一个ref的attribute属性


组件实例有一个$refs属性:


       他是一个Object,持有 注册过ref attribute 的所有DOM元素和组件实例

JavaScript
//  3 获取banner 组件: 组件实例
  // 不全等 实例,  以banner为模版 重新创建一个实例instance
  console.log(this.$refs.banner) // 拿到一个Proxy Proxy {bannerClick: ƒ, …}
  // 3 1 在父组件中可以主动的调用子组件的对象方法
  this.$refs.banner.bannerClick()
  // 3 2 获取banner组件实例,获取banner中的元素  拿到根元素
  console.log(this.$refs.banner.$el)
  // 3 3 如果banner template 是多个根 拿到的是 第一个Node节点
  // 但是我要拿到有用的东西 所以使用 nextSibling
  // 主: 开发中 不推荐组件中 有多个根元素
  console.log(this.$refs.banner.$el.nextSibling())

$parent和$root(了解)

K可以通过$parent访问父元素 $root访问根组件

三、动态组件的使用

切换组件案例

实现一个功能:


       点击一个 tab-bar 切换不同的组件显示


目前可以通过两种不同的实现思路实现:


       一:通过v-if来判断 显示不同的组件


       二:动态组件的方式

通过v-if实现:

JavaScript
<div class="view">
<!--      1 第一种做法 通过v-if判断逻辑来决定 显示哪一个组件-->
  <template v-if="currentIndex === 0">
    <home></home>
  </template>
  <template v-else-if="currentIndex === 1">
    <About></About>
  </template>
  <template v-else-if="currentIndex === 2">
    <Category></Category>
  </template>
</div>

通过 动态组件 实现:

动态组件使用 component组件 通过一个特殊的attribute is来实现

c32164481dbf468bb9e1af7f86fbec9e.png

这个currentTab的值需要是什么内容?


       全局注册:可以通过 component函数注册的组件


       布局注册:在一个 组件对象的components对象中注册的组件

动态组件的传值(应用较少)

如果是动态组件我们可以给它们传值和监听事件


       我们需要将 属性和监听事件 放到 component上来使用

JavaScript
<component name="xiong"
   :age="18"
   @homeClick="homeClick"
   :is="currentTab">
</component>


相关文章
|
4天前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
vue学习第四章
|
4天前
|
JavaScript 前端开发
vue学习第九章(v-model)
欢迎来到我的博客,我是瑞雨溪,一名热爱JavaScript与Vue的大一学生,自学前端2年半,正向全栈进发。此篇介绍v-model在不同表单元素中的应用及修饰符的使用,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
vue学习第九章(v-model)
|
4天前
|
JavaScript 前端开发 开发者
vue学习第十章(组件开发)
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文深入讲解Vue组件的基本使用、全局与局部组件、父子组件通信及数据传递等内容,适合前端开发者学习参考。持续更新中,期待您的关注!🎉🎉🎉
vue学习第十章(组件开发)
|
9天前
|
JavaScript 前端开发
如何在 Vue 项目中配置 Tree Shaking?
通过以上针对 Webpack 或 Rollup 的配置方法,就可以在 Vue 项目中有效地启用 Tree Shaking,从而优化项目的打包体积,提高项目的性能和加载速度。在实际配置过程中,需要根据项目的具体情况和需求,对配置进行适当的调整和优化。
|
10天前
|
存储 缓存 JavaScript
如何在大型 Vue 应用中有效地管理计算属性和侦听器
在大型 Vue 应用中,合理管理计算属性和侦听器是优化性能和维护性的关键。本文介绍了如何通过模块化、状态管理和避免冗余计算等方法,有效提升应用的响应性和可维护性。
|
9天前
|
JavaScript 前端开发 UED
vue学习第二章
欢迎来到我的博客!我是一名自学了2年半前端的大一学生,熟悉JavaScript与Vue,目前正在向全栈方向发展。如果你从我的博客中有所收获,欢迎关注我,我将持续更新更多优质文章。你的支持是我最大的动力!🎉🎉🎉
|
9天前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript和Vue的大一学生。自学前端2年半,熟悉JavaScript与Vue,正向全栈方向发展。博客内容涵盖Vue基础、列表展示及计数器案例等,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
|
10天前
|
存储 缓存 JavaScript
在 Vue 中使用 computed 和 watch 时,性能问题探讨
本文探讨了在 Vue.js 中使用 computed 计算属性和 watch 监听器时可能遇到的性能问题,并提供了优化建议,帮助开发者提高应用性能。
|
10天前
|
存储 缓存 JavaScript
Vue 中 computed 和 watch 的差异
Vue 中的 `computed` 和 `watch` 都用于处理数据变化,但使用场景不同。`computed` 用于计算属性,依赖于其他数据自动更新;`watch` 用于监听数据变化,执行异步或复杂操作。
下一篇
无影云桌面