百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Vue3 快速入门系列教程(一),什么是 Vue?

myzbx 2025-02-03 14:11 28 浏览

前言

本系列教程写给从事前端开发刚刚入门的小伙伴,以及即将从事前端开发的朋友们,不会涉及很深的技术原理,以“会使用”为目的。

初次写作,文章可能让您不满意,请见谅。

如果出现有关技术知识方面的错误,希望您可以指出,让我与您共同进步!

我真诚的希望我的文章能够帮到您。

正文

Vue 是一款用于构建用户界面的 JavaScript 框架。它是渐进式框架,基于标准 HTML、CSS 和 JavaScript 构建,并提供了一套声明式的、组件化的编程模型,帮助你高效地开发用户界面。

以上定义有3个地方需要留意:

渐进式框架:是指 Vue 具有很好的包容性,当你正在开发一个项目时,并非只能使用 Vue 这一项技术,你可以将你熟悉的技术集成到项目中。

声明式:就像我们在 HTML 中用 button 声明一个按钮一样,Vue 同样提供了一套类似 HTML 模板语法,它拓展了标准的 HTML 模板声明方式,使得我们可以使用“声明式”地方式描述最终输出的 HTML 和 JavaScript 状态之间的关系。这是 Vue 的一个核心功能。例如以下代码,很好的描述了该按钮“自增”意图的 JS 逻辑以及触发方式:

<button @click="count++">
  {{ count }}
</button>

组件化编程模型:Vue 将一个功能或页面的 HTML、CSS 和 JavaScript 代码合并到一起,这被成为组件,可以被其他组件或页面引入而重复利用。通常每个“.vue”文件作为一个组件,组件可以简单到由一个按钮组成,也可以复杂到由一组功能或页面组成。

我们工作中都是以“单文件组件”形式进行编码,本系列教程的代码示例也是采用这种方式。例如一个简单的“点赞组件”结构:

<template>
<div class="good">
<!-- 模板中的响应式变量不需要 .value -->
<span class="nums">获赞:{{goodNums}}</span>
<span>获赞 - 非响应式:{{testNums}}</span>
<span>
    <button @click="goodNumsAdd">点赞</button>
    <button @click="goodNums++">点赞的另一种触发方式</button>
    <button @click="testNumsAdd">点赞 - 非响应式</button>
</span>
</div>
</template>
<script setup>
import { ref } from 'vue'
const goodNums = ref(0)
const goodNumsAdd = () => {
    // 注意响应式变量在 JS 中要用 .value 
    goodNums.value++
}
let testNums = 0;
const testNumsAdd = () => {
    testNums++
    console.log('我触发了,值:' + testNums)
}
</script>
<style scoped>
.nums {
    color: red;
}
</style>


以上代码是 Vue 的一种书写方式,也是推荐的一种方式,有几点需要留意:

组件:一个组件由 template、script、style 标签组成。

<template>模板(视图)</template>
<script setup>
  // setup 属性开启组合式 API
</script>
<style scoped>
  /* scoped 属性指的是样式为该组件独享 */
</style>

组合式 API:<script setup> 是组合式 API 的使用方式,在开发中主要使用这种方式,本系列教程的代码示例也将采用这种方式。

<script setup>
  // setup 属性开启组合式 API
</script>

所谓组合式 API,可以简单理解成“把要实现的一个功能中用到的变量和函数放在一起”,这样的设计优势主要体现在代码的逻辑清晰、利于集中管理,例如下面代码中的“goodNums”和“testNums”。

<script setup>
import { ref } from 'vue'
// goodNums 响应式变量和处理方法放到一起
const goodNums = ref(0)
const goodNumsAdd = () => {
    // JS 中的响应式变量需要 .value
    goodNums.value++
}

// testNums 变量和处理方法放在一起
let testNums = 0; // 我也可以在模板中直接使用
const testNumsAdd = () => {
    testNums++
    console.log('我触发了,值:' + testNums)
}

// more...
// 如果有很多的功能,组合式 API 对代码的集中管理是很有优势的
</script>

组合式 API 还有一个特点:模板中可以直接使用 <script> 标签中声明的顶级变量和函数(指的是非函数中定义的变量和函数)。

JS 代码中使用响应式变量要用 .value,模板中不需要加 .value。

<template>
  <!-- 模板中直接使用响应式变量,但不需要 .value -->
  {{ goodNums }}
  <!-- 模板中直接使用非响应式变量 -->
  {{testNums}}
  <!-- 模板中直接使用 goodNumsAdd 方法 -->
  <button @click="goodNumsAdd">点赞</button>
</template>

如需“声明式”API 风格,请参阅 Vue 官方文档。

样式:<style scoped> 中的 scoped 代表 style 中的样式只针对该组件有效,这就意味着上面代码中的 class .nums 在别的组件中也被定义了,则它们的样式也不会互相干扰;

注意观察上面代码中的前两个按钮和第三个按钮的区别,前两个按钮点击后,模板中的“获赞”数字会出现变化,而且还是自增显示,这就是 Vue 的另一个核心功能“响应式”,Vue 会自动跟踪 JavaScript 状态并在其发生变化时响应式地更新 DOM,也可以简单的理解成:“数据发生了变化,页面就也跟着发生了变化,而无需手动刷新页面”。

const goodNums = ref(0) // 响应式,我变了,页面包含我的地方就会变了
let testNums = 0 // 不是响应式的,我变了,页面也不会改变

相反,第三个按钮点击后,即使是变量值发生变化,模板也不会更新,所以看不到“即时”的显示效果,因为它不是响应式的变量。

随后再点击前两个按钮中的任意一个,由于触发了视图更新,所以“获赞-非响应式”的值从最初的值立刻更新成最新值,且无自增显示效果,之前点击了几次“第三”个按钮,值就是几(多点击几次按钮观察结果)。

把一个变量变成响应式的,暂时记住“把它的初始值放到 ref() 函数的参数中”即可。

相关推荐

零基础入门AI智能体:详细了解什么是变量类型、JSON结构、Markdown格式

当品牌跳出固有框架,以跨界联动、场景创新叩击年轻群体的兴趣点,一场关于如何在迭代中保持鲜活的探索正在展开,既藏着破圈的巧思,也映照着与新一代对话的密码。在创建AI智能体时,我们会调用插件或大模型,而在...

C# 13模式匹配:递归模式与属性模式在真实代码中的性能影响分析

C#13对模式匹配的增强让复杂数据处理代码更简洁,但递归模式与属性模式的性能差异一直是开发者关注的焦点。在实际项目中,选择合适的模式不仅影响代码可读性,还可能导致执行效率的显著差异。本文结合真实测试...

零基础快速入门 VBA 系列 6 —— 常用对象(工作簿、工作表和区域)

上一节,我介绍了VBA内置函数以及如何自动打字和自动保存文件。这一节,我们来了解一下Excel常用对象。Excel常用对象Excel有很多对象,其中最常用也最重要的包括以下3个:1.Workbo...

不同生命数字的生肖龙!准到雷普!

属龙的人总在自信爆棚和自讨苦吃之间反复横跳?看完这届龙宝宝的日常我悟了。属龙的人好像天生自带矛盾体:领导力超强可人缘时好时坏,工作雷厉风行却总在爱情里翻车。关键年份的龙性格差异更大——76年龙靠谱但不...

仓颉编程语言基础-面向对象编程-属性(Properties)

属性是仓颉颉中一种强大的机制,它允许你封装对类(或接口interface、结构体struct、枚举enum、扩展extend)内部状态的访问。它看起来像一个普通的成员变量(字段),但在其背后,它通过...

Python中class对象/属性/方法/继承/多态/魔法方法详解

一、基础入门:认识类和对象1.类和对象的概念在Python中,类(class)是一种抽象的概念,用于定义对象的属性和行为,而对象(也称为实例)则是类的具体表现。比如,“汽车”可以是一个类,它有...

VBA基础入门:搞清楚对象、属性和方法就成功了一半

如果你刚接触VBA(VisualBasicforApplications),可能会被“对象”“属性”“方法”这些术语搞得一头雾水。但事实上,这三个概念是VBA编程的基石。只要理解它们之间的关系,...

P.O类型文推荐|年度编推合集(一百九十五篇)

点击左上方关注获取更多精彩推文目录2019年度编推35篇(1V1)《悖论》作者:流苏.txt(1V1)《桂花蒸》作者:大姑娘浪.txt(1V1)《豪门浪女》作者:奚行.txt...

Python参数传递内存大揭秘:可变对象 vs 不可变对象

90%的Python程序员不知道,函数参数传递中可变对象的修改竟会导致意想不到的副作用!一、参数传递的本质:对象引用传递在Python中,所有参数传递都是对象引用的传递。这意味着函数调用时传递的不是对...

JS 开发者必看!TC39 2025 最新动向,这些新语法要火?

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力。TC39第...

2025 年值得尝试的 5 个被低估的 JavaScript 库

这些JavaScript库可能不会在社交媒体或HackerNews上流行起来,但它们会显著提高您的工作效率和代码质量。JavaScript不再只是框架。虽然React、Vue和Sv...

Python自动化办公应用学习笔记30—函数的参数

一、函数的参数1.形参:o定义:在函数定义时,声明在函数名后面括号中的变量。o作用:它们是函数内部的占位符变量,用于接收函数被调用时传入的实际值。o生命周期:在函数被调用时创建,在函数执...

16种MBTI人格全解析|测完我沉默了三秒:原来我是这样的人?

MBTI性格测试火了这么久,你还不知道自己是哪一型?有人拿它当社交话题,有人拿它分析老板性格,还有人干脆当成择偶参考表。不废话,今天我一次性给你整理全部16种MBTI人格类型!看完你不仅能知道自己是谁...

JS基础与高级应用: 性能优化

在现代Web开发中,性能优化已成为前端工程师必须掌握的核心技能之一。本文从URL输入到页面加载完成的全过程出发,深入分析了HTTP协议的演进、域名解析、代码层面性能优化以及编译与渲染的最佳实践。通过节...

爱思创CSP-J/S初赛模拟赛线上开赛!助力冲入2024年CSP-J/S复赛!

CSP-J/S组初赛模拟赛爱思创,专注信奥教育19年,2022年CSP-J/S组赛事指定考点,特邀NOIP教练,开启全真实CSP-J/S组线上初赛模拟大赛!一、比赛对象:2024年备考CSP-J/S初...