Vue.js高阶学习和常用知识(二)

目录

      • [1. Vue 实例](#1. Vue 实例)
      • [2. 组件](#2. 组件)
      • [3. 指令](#3. 指令)
      • [4. 计算属性](#4. 计算属性)
      • [5. 监听器](#5. 监听器)
      • [6. 生命周期钩子](#6. 生命周期钩子)

Vue.js 是一个流行的 Web 前端框架,它由 Evan You 于 2014 年创建。Vue.js 的设计目标是简单、灵活和易于使用,同时具有高性能和可扩展性。
Vue.js 基于组件化的思想,将页面划分为多个组件,每个组件代表页面中的一个部分,可以独立开发、测试和部署。组件之间通过数据传递、事件监听和生命周期钩子等方式相互交互,使得开发人员可以更加方便地构建复杂的 Web 应用程序。
Vue.js 的核心库包括 Vue 实例、组件、指令、计算属性、监听器、生命周期钩子等,这些特性共同构成了 Vue.js 的基本功能。除此之外,Vue.js 还提供了很多插件和工具,例如 Vue Router、Vuex、Vue CLI 等,这些插件和工具可以让开发人员更加方便地开发和部署 Vue.js 应用程序。
在本文中,我们将详细介绍 Vue.js 的核心库和一些常用的插件和工具,帮助读者深入理解 Vue.js 的工作原理和应用场景。

1. Vue 实例

Vue.js 的核心概念之一是 Vue 实例,它是一个代表页面中的一个元素的 JavaScript 对象。每个 Vue 实例都包含一个数据对象、一个方法对象和一个渲染函数。开发人员可以通过 new Vue() 创建一个 Vue 实例,并通过 el 属性将该实例挂载到页面中的某个元素上。

例如,下面的代码创建了一个 Vue 实例,并将其挂载到 id 为 "app" 的元素上:

复制代码
var app = new Vue({  
 el: '#app',  
 data: {  
   message: 'Hello Vue!',  
 },  
 methods: {  
   reverseMessage: function () {  
     this.message = this.message.split('').reverse().join('')  
   }  
 }  
})  

在 Vue.js 中,开发人员可以通过 data 对象定义 Vue 实例的数据,并通过 methods 对象定义 Vue 实例的方法。Vue 实例的数据和方法可以在模板中使用,例如:

复制代码
<div id="app">  
 <p>{{ message }}</p>  
 <button v-on:click="reverseMessage">Reverse Message</button>  
</div>  

上面的模板中,我们使用了{{ message }}语法来显示 Vue 实例的数据,并使用了 v-on 指令来监听按钮的 click 事件,并调用 Vue 实例的方法 reverseMessage。

2. 组件

Vue.js 的另一个核心概念是组件,组件是 Vue.js 的模板中的基本构建块,可以重复使用和组合。组件是一个 JavaScript 对象,它包含一个模板、一个数据对象、一个方法对象和一个渲染函数。开发人员可以通过 Vue.js 的组件库或者自己编写组件来构建页面。

例如,下面的代码创建了一个名为 "HelloWorld" 的组件,该组件包含一个文本 "Hello World!":

复制代码
Vue.component('hello-world', {  
 template: 'Hello World!',  
})  

在上面的代码中,我们使用了 Vue.js 的组件库中的 hello-world 组件,并将其挂载到页面中的某个元素上。在模板中,我们可以使用该组件来构建页面,例如:

复制代码
<div id="app">  
 <hello-world></hello-world>  
</div>  

除了使用组件库中的组件之外,开发人员还可以自己编写组件。自己编写的组件需要使用 Vue.js 的单文件组件 (SFC) 格式来编写,例如:

复制代码
<template>  
 <div>  
   Hello World!  
 </div>  
</template>
<script>  
export default {  
 name: 'HelloWorld',  
 template: '#HelloWorld'  
}
</script>  

在上面的代码中,我们使用了 Vue.js 的 SFC 格式来编写一个名为 "HelloWorld" 的组件,该组件包含一个模板,并在 script 标签中定义了组件的 name 和 template。开发人员可以通过 import 语句将组件导入到其他文件中,并使用 Vue.js 的组件生命周期钩子来控制组件的状态和行为。

3. 指令

Vue.js 的指令是一个特殊的语法,它用于在模板中绑定数据和方法。指令是一个字符串,它包含一个冒号 (😃 和一个方法名称,例如:

html 复制代码
<div id="app">  
 <p v-bind:message="message"></p>  
</div>  

在上面的代码中,我们使用了 v-bind 指令来将 Vue 实例的 message 数据绑定到 p 元素的 message 属性上。这样,当 Vue 实例的 message 数据发生变化时,p 元素的 message 属性也会自动更新。

Vue.js 还提供了许多其他指令,例如 v-if、v-else-if、v-else、v-for、v-show 等,这些指令可以帮助开发人员更方便地操作 DOM 元素和数据。

4. 计算属性

Vue.js 的计算属性是一个特殊的属性,它用于在 Vue 实例中计算和更新数据。计算属性的值可以基于其他属性或者方法的值进行计算,当这些属性或方法的值发生变化时,计算属性的值也会自动更新。

例如,下面的代码定义了一个名为 message 的计算属性,它基于 Vue 实例的 name 属性计算出一个问候语:

javascript 复制代码
var app = new Vue({  
 el: '#app',  
 data: {  
   name: 'John'  
 },  
 computed: {  
   message: function () {  
     return 'Hello, ' + this.name + '!'  
   }  
 }  
})  

在上面的代码中,我们定义了一个 message 计算属性,它基于 Vue 实例的 name 属性计算出一个问候语。当 Vue 实例的 name 属性发生变化时,message 计算属性的值也会自动更新。在模板中,我们可以使用 {{ message }} 语法来显示 message 计算属性的值。

5. 监听器

Vue.js 的监听器是一个特殊的函数,它用于监听 Vue 实例的数据变化。当 Vue 实例的数据发生变化时,监听器函数会被自动调用。监听器函数可以接受一个或多个参数,这些参数表示发生变化的数据。

例如,下面的代码定义了一个名为 message 的监听器,它用于监听 Vue 实例的 message 数据变化:

javascript 复制代码
var app = new Vue({  
 el: '#app',  
 data: {  
   message: 'Hello Vue!'  
 },  
 methods: {  
   reverseMessage: function () {  
     this.message = this.message.split('').reverse().join('')  
   }  
 },  
 watch: {  
   message: function (value) {  
     console.log('Message has changed to: ' + value)  
   }  
 }  
})  

在上面的代码中,我们定义了一个 message 监听器,它用于监听 Vue 实例的 message 数据变化。当 Vue 实例的 message 数据发生变化时,watch 函数会被自动调用,并传入发生变化的数据作为参数。

6. 生命周期钩子

Vue.js 的生命周期钩子是一个特殊的函数,它用于控制 Vue 实例的生命周期。生命周期钩子函数可以在 Vue 实例的创建、挂载、更新、销毁等不同阶段被调用。

例如,下面的代码定义了一个名为 beforeCreate 的生命周期钩子,它用于在 Vue 实例创建之前做些准备工作:

javascript 复制代码
var app = new Vue({  
 el: '#app',  
 data: {  
   message: 'Hello Vue!'  
 },  
 beforeCreate: function () {  
   console.log('Before create')  
 },  
 created: function () {  
   console.log('Created')  
 },  
 beforeMount: function () {  
   console.log('Before mount')  
 },  
 mounted: function () {  
   console.log('Mounted')  
 },  
 beforeUpdate: function () {  
   console.log('Before update')  
 },  
 updated: function () {  
   console.log('Updated')  
 },  
 beforeDestroy: function () {  
   console.log('Before destroy')  
 },  
 destroyed: function () {  
   console.log('Destroyed')  
 }  
})  

在上面的代码中,我们定义了一系列生命周期钩子函数,这些函数分别在 Vue 实例的创建、挂载、更新、销毁等不同阶段被调用。下面是这些生命周期钩子函数的具体调用顺序:

  1. beforeCreate:在 Vue 实例创建之前被调用。此时,组件的 data、methods、computed 等数据都已初始化,但 DOM 元素还未被创建。
  2. created:在 Vue 实例创建完成之后被调用。此时,组件的 data、methods、computed 等数据都已初始化,且 DOM 元素已被创建。
  3. beforeMount:在 Vue 实例的模板编译完成并挂载到页面中之前被调用。此时,组件的模板已经被编译成渲染函数,但尚未将渲染函数挂载到页面中。
  4. mounted:在 Vue 实例的模板编译完成并挂载到页面中之后被调用。此时,组件的模板已经被编译成渲染函数,且渲染函数已被挂载到页面中。
  5. beforeUpdate:在 Vue 实例的数据更新之前被调用。此时,组件的 data 数据即将发生变化,但尚未重新渲染模板。
  6. updated:在 Vue 实例的数据更新之后被调用。此时,组件的 data 数据已经发生变化,且模板已经重新渲染。
  7. beforeDestroy:在 Vue 实例销毁之前被调用。此时,组件实例仍然完全可用,可以访问 data、methods 等数据。
  8. destroyed:在 Vue 实例销毁之后被调用。此时,组件实例已经完全销毁,无法访问 data、methods 等数据。
    通过在这些生命周期钩子函数中添加相应的逻辑,我们可以控制 Vue 实例在不同阶段的行为,例如在创建时做一些初始化操作,在销毁时做一些清理工作等。
相关推荐
LinXunFeng8 小时前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
乘风gg12 小时前
为什么AI 时代来临,大部分人吃不到红利
前端·ai编程·claude
恋猫de小郭12 小时前
Android 限制侧载新进展,谷歌联合国内厂商推验证计划
android·前端·flutter
IT_陈寒13 小时前
Redis内存爆了,原来我漏掉了这个致命配置
前端·人工智能·后端
恋猫de小郭13 小时前
解读 Android 17 全新内存限制,有没有“豁免”后门?
android·前端·flutter
Hyyy14 小时前
理解LLM的基本工作原理:预训练、微调、推理的区别
前端
Gatlin14 小时前
前端逆向与反逆向:一场猫鼠游戏的底层逻辑与实战
前端
Pedantic14 小时前
本地通知(Local Notifications)学习笔记
前端
森蓝情丶15 小时前
我给 AI 搭了个法庭:一个前端仔的 LangGraph 实战全记录
前端·后端
爱勇宝15 小时前
干了近 8 年,一夜之间被裁:AI 时代,程序员最该害怕的不是 AI
前端·后端·程序员