Vue:学习回顾

Vue (发音为 /vjuː/,类似 view) 是一款用于构建用户界面的JavaScript框架。它基于标准HTMLCSSJavaScript构建,并提供了一套声明式的、组件化的编程模型,帮助开发者高效地开发用户界面。 

Vue是一个独立的社区驱动的项目,它是由尤雨溪在2014年作为其个人项目创建, 是一个成熟的、经历了无数实战考验的框架,它是目前生产环境中使用最广泛的JavaScript框架之一,可以轻松处理大多数web应用的场景,并且几乎不需要手动优化,并且Vue完全有能力处理大规模的应用。 

一.vue环境搭建

  • Node.js 下载
Node:https://nodejs.p2hp.com/ // 访问 node 官网
  • 查看是否安装成功

二.使用Vite创建Vue应用

npm init vite-app
// 或者
yarn create vite
  • 添加你的项目名称

  • 选择 Vue

  • 选择JavaScript 或者 TypeScript

  • 运行你的项目
cd app
yarn
yarn dev

三.Vue的更新机制

Vue 的更新机制是指当数据发生变化时,Vue 是如何检测变化并更新相关的视图。

       Vue 使用了一种基于依赖追踪的观察者模式来实现更新机制。当一个 Vue 实例被创建时,Vue 会遍历该实例的数据对象,并使用 Object.defineProperty 方法将每个属性转换为 getter 和 setter。这样,当属性被访问或修改时,Vue 就能够捕获到对应的操作,并执行相应的更新。

        具体而言,Vue 的更新机制包括以下几个步骤:

  1. 初始化:在创建 Vue 实例时,Vue 会将 data 中的数据转化为响应式数据,并为每个响应式属性创建一个依赖追踪器(Dep)。

  2. 模板编译:Vue 会将模板编译为渲染函数,并在渲染函数中解析模板中的指令和表达式。

  3. 首次渲染:Vue 在首次渲染时会执行渲染函数,并将生成的虚拟 DOM 渲染为真实的 DOM 元素,完成页面的初次渲染。

  4. 依赖收集:在渲染过程中,当访问响应式数据时,会触发 getter 方法,此时会将当前组件的 Watcher 添加到该属性的依赖追踪器中。

  5. 响应式更新:当响应式数据发生变化时,会触发 setter 方法,这时会通知依赖追踪器中的所有 Watcher 执行更新操作。

  6. 虚拟 DOM 更新:Vue 使用虚拟 DOM 来优化性能,当执行更新操作时,Vue 会生成新的虚拟 DOM,并通过 diff 算法比较新旧虚拟 DOM 的差异,然后只对需要更新的部分进行真实 DOM 的操作,从而最小化对 DOM 的操作。

  7. 视图更新:通过对比新旧虚拟 DOM 的差异,Vue 只更新需要更新的部分,然后将更新后的结果渲染到页面上,完成视图的更新。

        通过以上的更新机制,Vue 能够高效地追踪数据的变化,并将变化应用到相关的视图上,从而实现了快速、自动化的视图更新。这个机制使得开发者可以专注于数据的变化,而不需要手动操作 DOM,提高了开发效率和代码的可维护性。

四.组件化思想

Vue 组件化思想是指将应用程序拆分为多个独立、可复用的组件,每个组件都有自己的模板、逻辑和样式。组件化思想的核心概念是将复杂的用户界面拆分成一系列小而简单的部分,每个部分都有明确定义的功能和责任。

        在 Vue 中,一个组件可以包含以下几个方面

  1. 模板(Template):组件的模板定义了组件的结构和布局,采用类似 HTML 的标记语法,可以嵌套其他组件或 HTML 元素。模板中可以使用 Vue 的指令和表达式来绑定数据和动态生成内容。

  2. 数据(Data):每个组件都有自己的数据,用于存储组件内部的状态和变量。数据可以在组件的模板中使用,通过 Vue 的响应式系统进行绑定,当数据发生变化时,相关的视图会自动更新。

  3. 方法(Methods):组件可以定义一些方法来处理用户的交互、触发事件或执行其他逻辑操作。方法可以绑定到模板中的事件监听器,或者通过其他方式在组件内部调用。

  4. 样式(Style):每个组件可以有自己的样式,可以使用 CSS 或 CSS 预处理器来定义组件的外观和样式规则。样式可以以普通的 CSS 文件或者在组件内部通过 <style> 标签的方式进行定义。

        通过将应用程序拆分为多个小而简单的组件,可以提高代码的可维护性和可读性。每个组件都有自己的职责,可以独立开发、测试和重用。在复杂的应用程序中,组件化思想能够有效地提升开发效率,并促进团队合作和代码复用。同时,Vue 提供了丰富的组件通信和组合方式,使得组件之间的交互变得更加灵活和方便。

五.Vue和Ts的兼容性

        Vue.js 和 TypeScript 是两个不同的技术,Vue.js 是一种 JavaScript 框架,而 TypeScript 是一门静态类型语言。虽然 Vue.js 本身是基于 JavaScript 的,但是它与 TypeScript 也有很好的兼容性。

  1. TypeScript 的数据类型和接口可以被 Vue.js 支持:在 Vue.js 中,我们可以使用 TypeScript 定义变量、函数参数、组件属性等数据类型。例如,在 Vue 组件中,我们可以使用 props 属性定义组件的属性,使用 data 属性定义组件的状态,使用 computed 属性定义计算属性等。这些属性的类型可以通过 TypeScript 进行定义和检查,从而提高代码的健壮性和可维护性。

  2. Vue.js 可以使用 TypeScript 编写组件:Vue.js 提供了一个 vue-class-component 库,可以让我们使用 TypeScript 类来编写 Vue 组件。这样我们就可以使用类的装饰器来定义组件的选项、生命周期钩子、计算属性等,从而使代码更加模块化和易于维护。

  3. Vue.js 可以使用 TypeScript 定义插件和指令:在 Vue.js 中,我们可以使用 TypeScript 来定义自定义指令和全局插件。通过 TypeScript 的类型定义,我们可以确保插件和指令被正确地使用和调用,从而提高代码的可读性和可靠性。

  4. Vue.js CLI 支持 TypeScript:Vue.js CLI 是 Vue.js 的官方脚手架工具,可以帮助我们快速搭建 Vue.js 项目的开发环境。Vue.js CLI 支持使用 TypeScript 来编写 Vue.js 应用。我们可以通过 vue create 命令初始化一个 TypeScript 项目,也可以通过 vue add @vue/typescript 命令将 TypeScript 添加到已有的 Vue.js 项目中。

        综上所述,Vue.js 和 TypeScript 有很好的兼容性。Vue.js 提供了丰富的 API 和选项,可以让我们使用 TypeScript 来增强代码的类型检查和可靠性,从而提高代码质量和开发效率。

六.Vue与Ts

在 Vue.js 中使用 TypeScript,可以提供额外的类型检查和类型推断,从而增强代码的可读性、可维护性和健壮性。下面是在 Vue.js 中编写 TypeScript 的一些注意事项

        1.安装 TypeScript:首先,确保你已经安装了 TypeScript。可以通过运行以下命令来全局安装 TypeScript:

npm install -g typescript

         2.使用 <script lang="ts"> 标签:在单文件组件中,将 <script> 标签的 lang 属性设置为 "ts",告诉 Vue.js 这是一个 TypeScript 文件。

<script lang="ts" setup>

</script

         3.类型定义:在 Vue 组件中,可以使用 TypeScript 来定义属性、状态、计算属性等的类型。使用 Props 接口来定义组件的属性,使用 data 方法并指定返回类型来定义组件的状态。例如

<script lang="ts">
import { Vue, Component } from 'vue-property-decorator';

interface Props {
  name: string;
}

@Component
export default class MyComponent extends Vue {
  // 定义组件的属性
  private props!: Props;

  // 定义组件的状态
  private data(): { count: number } {
    return {
      count: 0,
    };
  }

  // 定义计算属性
  private get doubledCount(): number {
    return this.count * 2;
  }
}
</script>

           4.钩子函数:在 TypeScript 中,可以使用装饰器来定义生命周期钩子函数。例如,使用 @Lifecycle 装饰器来定义 created 钩子函数 

import { Vue, Component, Lifecycle } from 'vue-property-decorator';

@Component
export default class MyComponent extends Vue {
  @Lifecycle
  private created() {
    // 在组件创建时执行的逻辑
  }
}

           5.使用类样式绑定:在 Vue 组件中,可以使用 class 绑定来动态设置 HTML 元素的类。在 TypeScript 中,你可以使用对象语法来设置类样式绑定,并在编译时进行类型检查。例如

<template>
  <div :class="{ active: isActive }">内容</div>
</template>

<script lang="ts">
import { Vue, Component } from 'vue-property-decorator';

@Component
export default class MyComponent extends Vue {
  private isActive = true;
}
</script>

        6.导入其他模块:在 TypeScript 中,可以使用 import 语句来导入其他模块。例如,导入一个外部的库:

import Vue from 'vue';
import { Component } from 'vue-property-decorator';

        这些是在 Vue.js 中使用 TypeScript 的一些基本注意事项。使用 TypeScript 可以帮助我们在开发过程中捕获潜在的错误,提高代码质量和开发效率。但请注意,在编写 TypeScript 时,要确保正确地定义类型,并遵循 TypeScript 的语法规则。同时,建议参考 Vue.js 官方文档和 TypeScript 文档,以获取更详细的信息和示例。

七.Vue和pinia

Vue.js 是一个流行的 JavaScript 框架,用于构建用户界面。而 Pinia 是一个基于 Vue 3 的状态管理库,它提供了一种简洁、直观的方式用于管理应用程序的状态。

如果你想在 Vue.js 中使用 TypeScript 并结合 Pinia 进行状态管理,可以按照以下步骤进行设置:

  1. 安装 Pinia:打开终端,进入项目目录并运行以下命令来安装 Pinia 和相关的依赖:
npm install pinia
// 或
yarn add pinia

        2. 创建和配置 Pinia Store:创建一个名为 store.ts 的文件,用于定义和配置 Pinia Store。在该文件中,可以定义状态、操作和 getter。例如:

import { defineStore } from 'pinia';

// 定义状态
interface CounterState {
  count: number;
}

export const useCounterStore = defineStore('counter', {
  state: (): CounterState => ({
    count: 0,
  }),
  actions: {
    increment() {
      this.count++;
    },
  },
  getters: {
    doubleCount(): number {
      return this.count * 2;
    },
  },
});

          3. 在 Vue 组件中使用 Pinia Store:在需要使用 Pinia Store 的组件中,可以通过 useStore 函数来引入并使用 Pinia Store。例如:

<script lang="ts" setup>
import { defineComponent } from 'vue';
import { useCounterStore } from './store';

const counterStore = useCounterStore();

const increment = () => {
    counterStore.increment();
};

});
</script>

        通过 useCounterStore 函数获取到的 counterStore 对象,可以访问状态、操作和 getter。

        4.在应用程序的入口文件中注册 Pinia 插件:在你的应用程序的入口文件(通常是 main.ts)中,需要注册 Pinia 插件。例如:

        

import { createApp } from 'vue';
import { createPinia } from 'pinia';
import App from './App.vue';

const app = createApp(App);

// 注册 Pinia 插件
app.use(createPinia());

app.mount('#app');

通过以上步骤,你就可以在 Vue.js 中使用 TypeScript 并结合 Pinia 进行状态管理了。记得参考 Vue.js 和 Pinia 的官方文档,以获取更详细的信息和示例。

八.总结

总体而言,该博文提供了一个全面而且易于理解的 Vue.js 学习指南。通过清晰的示例代码和详细的解释,该博文帮助读者掌握了 Vue.js 的核心概念和常用功能。无论是初学者还是有经验的开发人员,该博文都提供了进一步深入学习的资源。

  • 19
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

韦韦诺诺

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值