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>


相关文章
|
1天前
|
资源调度 JavaScript 前端开发
Vue Router 的使用方式是什么
【8月更文挑战第30天】Vue Router 的使用方式是什么
8 2
|
2天前
|
JavaScript
Vue多图组合走马灯
这篇文章介绍了如何在Vue框架中创建一个多图组合的走马灯组件,允许自定义滑动间隔和图片区域宽度,以展示多个图片。
Vue多图组合走马灯
|
1天前
|
JavaScript 前端开发 测试技术
Vue.js开发者必看!Vue Test Utils携手端到端测试,打造无懈可击的应用体验,引领前端测试新风尚!
【8月更文挑战第30天】随着Vue.js的普及,构建可靠的Vue应用至关重要。测试不仅能确保应用质量,还能提升开发效率。Vue Test Utils作为官方测试库,方便进行单元测试,而结合端到端(E2E)测试,则能构建全面的测试体系,保障应用稳定性。本文将带你深入了解如何使用Vue Test Utils进行单元测试,通过具体示例展示如何测试组件行为;并通过Cypress进行E2E测试,确保整个应用流程的正确性。无论是单元测试还是E2E测试,都能显著提高Vue应用的质量,让你更加自信地交付高质量的应用。
|
1天前
|
JavaScript 前端开发 UED
服务器端渲染新浪潮:用Vue.js和Nuxt.js构建高性能Web应用
【8月更文挑战第30天】在现代Web开发中,提升应用性能和SEO友好性是前端开发者面临的挑战。服务器端渲染(SSR)能加快页面加载速度并改善搜索引擎优化。Vue.js结合Nuxt.js提供了一个高效框架来创建SSR应用。通过安装`create-nuxt-app`,可以轻松创建新的Nuxt.js项目,并利用其自动路由功能简化页面管理。Nuxt.js默认采用SSR模式,并支持通过`asyncData`方法预取数据,同时提供了静态站点生成和服务器端渲染的部署选项,显著提升用户体验。
|
1天前
|
JavaScript 前端开发 API
全栈开发革命来临!Vue.js与Node.js联手,打造前后端无缝对接的奇迹之作!
【8月更文挑战第30天】在Web开发领域,前后端分离与协作至关重要。Vue.js以其轻量级和易用性深受前端开发者喜爱,而Node.js则以高性能和事件驱动特性在后端领域崭露头角。二者结合开启了全栈开发新篇章,通过RESTful API或GraphQL实现高效稳定通信。本文以示例说明如何使用Vue.js和Node.js构建全栈应用,从前端Vue组件到后端Express服务器,展示了数据获取与展示的全过程。这种组合提供了一种高效简洁的全栈开发方案,使开发者能更专注于业务逻辑实现。
|
1天前
|
JavaScript 前端开发 UED
揭秘Vue.js高效开发:Vue Router如何让单页面应用路由管理变得如此简单?
【8月更文挑战第30天】随着Web应用复杂性的增加,单页面应用(SPA)因出色的用户体验和高效的页面加载性能而备受青睐。Vue.js凭借简洁的语法和灵活的组件系统成为构建SPA的热门选择,其官方路由管理器Vue Router则简化了路由管理。本文通过实战示例介绍如何利用Vue Router实现高效的SPA路由管理,包括命名路由、动态路由及其核心优势。
|
1天前
|
JavaScript API 网络架构
vue 动态路由使用
【8月更文挑战第30天】vue 动态路由使用
10 0
|
1天前
|
JavaScript
vue知识点
vue知识点
6 0
|
2月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
65 2
|
2月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的宠物援助平台附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的宠物援助平台附带文章源码部署视频讲解等
59 4