Vue.js 学习笔记
文章目录
- 前言
- 一、Vue.js 基础概念
- 1.1 Vue.js 简介
- 1.2 Vue.js 的特点
- 1.3 Vue.js 基础示例
- 二、Vue.js 常用指令
- 2.1 双向数据绑定(`v-model`)
- 2.2 条件渲染(`v-if` 和 `v-show`)
- 2.3 列表渲染(`v-for`)
- 2.4 事件处理(`v-on`)
- 2.5 表单绑定(`v-model`)
- 三、Vue.js 组件化开发
- 3.1 组件的概念
- 3.2 创建组件
- 3.2.1 全局注册
- 3.2.2 局部注册
- 3.3 组件间通信
- 3.3.1 父子组件通信
- 3.4 组件的生命周期
- 四、Vue.js 计算属性与侦听器
- 4.1 计算属性
- 4.2 侦听器
- 五、Vue.js 路由与状态管理
- 5.1 Vue Router
- 5.2 Vuex
- 六、总结
前言
在前端开发领域,Vue.js 以其轻量级、易上手和高性能的特点,赢得了众多开发者的青睐。作为一名前端小白,我也踏上了学习 Vue.js 的旅程。本文将分享我的学习笔记,涵盖 Vue.js 的基础概念、常用指令、组件化开发、计算属性与侦听器、路由和状态管理等知识点,并附上代码示例,希望能帮助到同样在学习 Vue.js 的你。
一、Vue.js 基础概念
1.1 Vue.js 简介
Vue.js 是一款用于构建用户界面的渐进式 JavaScript 框架。它采用直观的模板语法,降低了学习成本,并通过响应式数据绑定,实现了数据与视图的自动同步更新。Vue.js 的组件化开发模式,使代码结构更加清晰、可维护性强,非常适合构建大型应用。
1.2 Vue.js 的特点
- 易学易用:Vue.js 的 API 设计简洁明了,即使是初学者也能快速上手。
- 响应式数据绑定:通过双向绑定(
v-model),数据与视图能够自动同步更新,减少了手动操作 DOM 的繁琐。 - 组件化开发:将 UI 界面拆分成多个独立的组件,提高了代码的复用性和可维护性。
- 生态丰富:Vue.js 拥有完善的生态系统,包括 Vue Router、Vuex 等官方维护的配套工具,方便构建单页应用(SPA)。
1.3 Vue.js 基础示例
下面是一个简单的 Vue.js 实例,展示了数据绑定和事件处理的基本用法:
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Vue.js 基础示例</title><script src="https://cdn.jsdelivr.net/npm/vue@3"></script>
</head>
<body><div id="app"><h1>{{ message }}</h1><button @click="changeMessage">点击修改消息</button></div><script>const app = Vue.createApp({data() {return {message: 'Hello, Vue.js!'};},methods: {changeMessage() {this.message = '消息已修改!';}}});app.mount('#app');</script>
</body>
</html>
在上述代码中,我们通过 data 函数定义了组件的数据 message,并通过 methods 定义了点击按钮时触发的方法 changeMessage。在模板中,使用 {{ message }} 实现了数据的插值显示,使用 @click 指令绑定了点击事件。
二、Vue.js 常用指令
2.1 双向数据绑定(v-model)
v-model 指令用于实现表单输入和应用状态之间的双向数据绑定。当输入框的值发生变化时,绑定的数据也会自动更新,反之亦然。
<div id="app"><input v-model="message" placeholder="编辑消息"><p>输入的消息是:{{ message }}</p>
</div><script>const app = Vue.createApp({data() {return {message: 'Hello, Vue!'};}});app.mount('#app');
</script>
2.2 条件渲染(v-if 和 v-show)
v-if 指令用于条件渲染,只有在条件为 true 时,元素才会被渲染到 DOM 中。而 v-show 指令则是通过 CSS 的 display 属性来控制元素的显示和隐藏,元素始终存在于 DOM 中。
<div id="app"><button @click="toggle">切换显示</button><p v-if="isVisible">现在你看到我了</p><p v-show="isVisible">我也能切换显示</p>
</div><script>const app = Vue.createApp({data() {return {isVisible: true};},methods: {toggle() {this.isVisible = !this.isVisible;}}});app.mount('#app');
</script>
2.3 列表渲染(v-for)
v-for 指令用于遍历数组或对象,并渲染列表。在使用 v-for 时,建议为每个列表项指定一个唯一的 key 属性,以提高渲染性能。
<div id="app"><ul><li v-for="(item, index) in items" :key="index">{{ item }}</li></ul>
</div><script>const app = Vue.createApp({data() {return {items: ['苹果', '香蕉', '橙子', '葡萄']};}});app.mount('#app');
</script>
2.4 事件处理(v-on)
v-on 指令用于监听 DOM 事件,并在事件触发时执行相应的 JavaScript 代码。在 Vue.js 中,事件处理函数可以定义在组件的 methods 中。
<div id="app"><button v-on:click="sayHello">点击我</button><p>你点击了 {{ count }} 次</p>
</div><script>const app = Vue.createApp({data() {return {count: 0};},methods: {sayHello() {this.count++;alert('你好,Vue.js!');}}});app.mount('#app');
</script>
2.5 表单绑定(v-model)
v-model 指令用于实现表单输入和应用状态之间的双向绑定。当输入框的值发生变化时,绑定的数据也会自动更新,反之亦然。
<div id="app"><input v-model="message" placeholder="输入消息"><p>你输入的消息是:{{ message }}</p>
</div><script>const app = Vue.createApp({data() {return {message: ''};}});app.mount('#app');
</script>
三、Vue.js 组件化开发
3.1 组件的概念
组件是 Vue.js 最强大的功能之一,它允许我们将 UI 拆分成独立、可复用的部分。通过组件化开发,我们可以将复杂的界面分解为多个简单的组件,提高代码的可维护性和复用性。
3.2 创建组件
3.2.1 全局注册
全局注册的组件可以在整个 Vue 应用中使用。我们可以通过 app.component 方法进行全局注册。
<div id="app"><my-component></my-component>
</div><script>const MyComponent = {template: '<p>这是一个全局注册的组件</p>'};const app = Vue.createApp({});app.component('my-component', MyComponent);app.mount('#app');
</script>
3.2.2 局部注册
局部注册的组件只能在当前组件中使用。我们可以通过 components 选项来局部注册组件。
<div id="app"><child-component></child-component>
</div><script>const ChildComponent = {template: '<p>这是一个局部注册的组件</p>'};const app = Vue.createApp({components: {'child-component': ChildComponent}});app.mount('#app');
</script>
3.3 组件间通信
3.3.1 父子组件通信
父子组件之间的通信可以通过 props 和 emit 实现。父组件可以通过 props 向子组件传递数据,子组件可以通过 emit 向父组件发送事件。
父组件:
<div id="app"><child-component :message="parentMessage" @update-message="updateMessage"></child-component>
</div><script>const ChildComponent = {props: ['message'],template: `<div><p>子组件收到的消息:{{ message }}</p><input v-model="childMessage" @input="sendMessage"></div>`,data() {return {childMessage: ''};},methods: {sendMessage() {this.$emit('update-message', this.childMessage);}}};const app = Vue.createApp({data() {return {parentMessage: '你好,子组件!'};},components: {'child-component': ChildComponent},methods: {updateMessage(newMessage) {this.parentMessage = newMessage;}}});app.mount('#app');
</script>
3.4 组件的生命周期
组件的生命周期是指组件从创建到销毁的整个过程。Vue.js 提供了一系列的生命周期钩子函数,我们可以在这些钩子函数中执行特定的逻辑。
<div id="app"><button @click="toggleComponent">切换组件</button><div v-if="showComponent"><my-component></my-component></div>
</div><script>const MyComponent = {template: '<p>这是一个生命周期示例组件</p>',data() {return {count: 0};},beforeCreate() {console.log('组件创建前');},created() {console.log('组件创建后');},beforeMount() {console.log('组件挂载前');},mounted() {console.log('组件挂载后');},beforeUpdate() {console.log('组件更新前');},updated() {console.log('组件更新后');},beforeUnmount() {console.log('组件卸载前');},unmounted() {console.log('组件卸载后');}};const app = Vue.createApp({data() {return {showComponent: true};},methods: {toggleComponent() {this.showComponent = !this.showComponent;}}});app.mount('#app');
</script>
四、Vue.js 计算属性与侦听器
4.1 计算属性
计算属性是基于其依赖项进行计算的属性。计算属性会根据依赖项的变化自动更新,非常适合用于需要根据数据进行复杂计算的场景。
<div id="app"><p>原消息:{{ message }}</p><p>计算后的消息:{{ computedMessage }}</p><button @click="changeMessage">修改消息</button>
</div><script>const app = Vue.createApp({data() {return {message: 'Hello, Vue.js!'};},computed: {computedMessage() {return this.message.toUpperCase();}},methods: {changeMessage() {this.message = '消息已修改!';}}});app.mount('#app');
</script>
4.2 侦听器
侦听器用于监听数据的变化,并在数据变化时执行特定的逻辑。侦听器可以通过 watch 选项来定义。
<div id="app"><p>输入的消息:{{ message }}</p><input v-model="message" placeholder="输入消息">
</div><script>const app = Vue.createApp({data() {return {message: ''};},watch: {message(newVal, oldVal) {console.log(`消息从 ${oldVal} 变为 ${newVal}`);}}});app.mount('#app');
</script>
五、Vue.js 路由与状态管理
5.1 Vue Router
Vue Router 是 Vue.js 的官方路由库,用于构建单页应用(SPA)。通过 Vue Router,我们可以实现页面的动态跳转和路由管理。
安装 Vue Router:
npm install vue-router
基本用法:
<div id="app"><router-link to="/home">首页</router-link><router-link to="/about">关于</router-link><router-view></router-view>
</div><script>import { createApp } from 'vue';import { createRouter, createWebHistory } from 'vue-router';const Home = { template: '<p>这是首页</p>' };const About = { template: '<p>这是关于页</p>' };const routes = [{ path: '/home', component: Home },{ path: '/about', component: About }];const router = createRouter({history: createWebHistory(),routes});const app = createApp({});app.use(router);app.mount('#app');
</script>
5.2 Vuex
Vuex 是 Vue.js 的官方状态管理库,用于集中管理应用的状态。通过 Vuex,我们可以实现组件之间的状态共享和状态管理。
安装 Vuex:
npm install vuex
基本用法:
<div id="app"><div>{{ count }}</div><button @click="increment">增加</button><button @click="decrement">减少</button>
</div><script>import { createApp } from 'vue';import { createStore } from 'vuex';const store = createStore({state: {count: 0},mutations: {increment(state) {state.count++;},decrement(state) {state.count--;}}});const app = createApp({});app.use(store);app.mount('#app');
</script>
六、总结
通过以上的学习,我们掌握了 Vue.js 的基础概念、常用指令、组件化开发、计算属性与侦听器、路由和状态管理等知识点。Vue.js 以其简洁的语法和强大的功能,为我们提供了高效的前端开发体验。希望这些学习笔记能帮助你更好地理解和使用 Vue.js,开启你的前端开发之旅!
相关文章:
Vue.js 学习笔记
文章目录 前言一、Vue.js 基础概念1.1 Vue.js 简介1.2 Vue.js 的特点1.3 Vue.js 基础示例 二、Vue.js 常用指令2.1 双向数据绑定(v-model)2.2 条件渲染(v-if 和 v-show)2.3 列表渲染(v-for)2.4 事件处理&am…...
数据存储:一文掌握RabbitMQ的详细使用
文章目录 一、RabbitMQ简介二、RabbitMQ的概述2.1 基本概念2.2 实际应用场景三、RabbitMQ的安装与配置3.1 安装RabbitMQ3.2 启用管理插件四、使用Python操作RabbitMQ4.1 安装Pika库4.2 生产者示例4.3 消费者示例4.4 发布/订阅模式示例五、RabbitMQ的高级特性5.1 消息持久化5.2 …...
辛格迪客户案例 | 祐儿医药科技GMP培训管理(TMS)项目
01 项目背景:顺应行业趋势,弥补管理短板 随着医药科技行业的快速发展,相关法规和标准不断更新,对企业的质量管理和人员培训提出了更高要求。祐儿医药科技有限公司(以下简称“祐儿医药”)作为一家专注于创新…...
FreeRtos实时系统: 十六.tickless低功耗模式
FreeRtos实时系统: 十六.tickless低功耗模式 一.tickless低功耗模式简介二.tickless模式详解三.tickless模式相关配置项四.tickless低功耗模式实验五.课堂总结 一.tickless低功耗模式简介 STM32低功耗模式: 二.tickless模式详解 为了可以降低功耗,又不…...
CSDN博客:Markdown编辑语法教程总结教程(上)
❤个人主页:折枝寄北的博客 Markdown编辑语法教程总结 前言1. CSDN Markdown编辑器功能简介1.1 基础操作界面1.2 创作助手和语法说明 2. Markdown编辑器语法2.1 目录2.2 标题2.2.1 标题级别设置2.2.2 标题居中 3. 文本样式3.1 强调文本(斜体)…...
多个pdf合并成一个pdf的方法
将多个PDF文件合并优点: 能更容易地对其进行归档和备份.打印时可以选择双面打印,减少纸张的浪费。比如把住宿发票以及滴滴发票、行程单等生成一个pdf,双面打印或者无纸化办公情况下直接发送给财务进行存档。 方法: 利用PDF24 Tools网站 …...
Spark基础篇 RDD、DataFrame与DataSet的关系、适用场景与演进趋势
一、核心概念与演进背景 1.1 RDD(弹性分布式数据集) 定义:RDD 是 Spark 最早的核心抽象(1.0版本引入),代表不可变、分区的分布式对象集合,支持函数式编程和容错机制。特点: 无结构化信息:仅存储对象本身,无法自动感知数据内部结构(如字段名、类型)。编译时类型安全…...
odoo初始化数据库
在 Odoo 中,初始化数据库的命令会因使用的环境和启动方式而有所不同,下面为你详细介绍几种常见的初始化数据库的方式。 1. 使用命令行工具初始化 在命令行中,你可以使用 Odoo 的启动脚本并结合相关参数来初始化数据库。以下是基本的命令格式…...
大模型WebUI:Gradio全解12——LangChain原理、架构和组件(2)
大模型WebUI:Gradio全解12——LangChain原理、架构和组件(2) 前言12. LangChain原理及agents构建Gradio UI12.2 学习资料12.2.1 学习文档12.2.2 用途示例12.2.3 OpenAI和DeepSeek例程1. OpenAI示例2. DeepSeek例程参考文献前言 本系列文章主要介绍WEB界面工具Gradio。Gradi…...
1. 搭建前端+后端开发框架
1. 说明 本篇博客主要介绍网页开发中,搭建前端和后端开发框架的具体步骤,框架中所使用的技术栈如下: 前端:VUE Javascript 后端:Python Flask Mysql 其中MySQL主要用来存储需要的数据,在本文中搭建基本…...
初会学习记录
目录 务实: 第一章 (1)会计概念,职能和目标: (2)会计假设: (3)会计核算基础: (4)会计信息质量要求: (5)会计人员职业道德规范 (6)会计准则制度体系概述: (7)会计要素与会计等式&#x…...
DeepSeek 使用窍门与提示词写法指南
一、通用提示词技巧 窍门分类技巧说明示例提示词明确需求用“角色任务要求”明确目标作为健身教练,为30岁上班族设计一周减脂计划,需包含饮食和15分钟居家训练结构化提问分步骤、分模块提问第一步:列出Python爬虫必备的5个库;第二…...
【大模型】DeepSeek核心技术之MLA (Multi-head Latent Attention)
文章目录 1. Multi-Head Attention (MHA)2. Multi-head Latent Attention (MLA)2.1 低秩压缩2.2 应用RoPE2.3 矩阵融合 参考资料 在讲解MLA之前,需要大家对几个基础的概念(KV Cache, Grouped-Query Attention (GQA), Multi-Query Attention (…...
七、JOIN 语法详解与实战示例
一、JOIN 的作用与分类 JOIN 操作用于合并两个或多个表的行,基于表之间的关联字段。以下是常见的 JOIN 类型: JOIN 类型描述INNER JOIN返回两个表匹配的记录LEFT JOIN返回左表所有记录 右表匹配记录(右表无匹配则为NULL)RIGHT …...
Skynet入门(一)
概念 skynet 是一个为网络游戏服务器设计的轻量框架。但它本身并没有任何为网络游戏业务而特别设计的部分,所以尽可以把它用于其它领域。 设计初衷 如何充分利用它们并行运作数千个相互独立的业务。 模块设计建议 在 skynet 中,用服务 (service) 这…...
单片机栈和堆、FALSH、区别
1. Flash(闪存)(程序存储器) 用途 存储程序代码:编译后的机器指令(如 .text 段)、常量数据(如 .rodata 段)等。 掉电不丢失:程序固化在 Flash 中࿰…...
【FL0090】基于SSM和微信小程序的球馆预约系统
🧑💻博主介绍🧑💻 全网粉丝10W,CSDN全栈领域优质创作者,博客之星、掘金/知乎/b站/华为云/阿里云等平台优质作者、专注于Java、小程序/APP、python、大数据等技术领域和毕业项目实战,以及程序定制化开发…...
如何把word文档整个文档插入到excel表格里?
现象: 当我们双击此文档时可以快速打开对应的word文档 实现步骤: 1、点击一下要插入的excel表格里的单元格 2、选择上方的的【插入】【附件】的下拉框下的【对象】 3、选择【由文件创建】-【浏览】 再在弹出的框中选择【桌面】,选择要插…...
PDF文档中表格以及形状解析
我们在做PDF文档解析时有时需要解析PDF文档中的表格、形状等数据。跟解析文本类似的常见的解决方案也是两种。文档解析跟ocr技术处理。下面我们来看看使用文档解析的方案来做PDF文档中的表格、图形解析(使用pdfium库)。 表格解析: 在pdfium库…...
C++20 Lambda表达式新特性:包扩展与初始化捕获的强强联合
文章目录 一、Lambda表达式的历史回顾二、C20 Lambda表达式的两大新特性(一)初始化捕获(Init-Capture)(二)包扩展(Pack Expansion) 三、结合使用初始化捕获与包扩展(一&a…...
利用最小二乘法找圆心和半径
#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …...
Vim 调用外部命令学习笔记
Vim 外部命令集成完全指南 文章目录 Vim 外部命令集成完全指南核心概念理解命令语法解析语法对比 常用外部命令详解文本排序与去重文本筛选与搜索高级 grep 搜索技巧文本替换与编辑字符处理高级文本处理编程语言处理其他实用命令 范围操作示例指定行范围处理复合命令示例 实用技…...
云启出海,智联未来|阿里云网络「企业出海」系列客户沙龙上海站圆满落地
借阿里云中企出海大会的东风,以**「云启出海,智联未来|打造安全可靠的出海云网络引擎」为主题的阿里云企业出海客户沙龙云网络&安全专场于5.28日下午在上海顺利举办,现场吸引了来自携程、小红书、米哈游、哔哩哔哩、波克城市、…...
ServerTrust 并非唯一
NSURLAuthenticationMethodServerTrust 只是 authenticationMethod 的冰山一角 要理解 NSURLAuthenticationMethodServerTrust, 首先要明白它只是 authenticationMethod 的选项之一, 并非唯一 1 先厘清概念 点说明authenticationMethodURLAuthenticationChallenge.protectionS…...
JDK 17 新特性
#JDK 17 新特性 /**************** 文本块 *****************/ python/scala中早就支持,不稀奇 String json “”" { “name”: “Java”, “version”: 17 } “”"; /**************** Switch 语句 -> 表达式 *****************/ 挺好的ÿ…...
.Net Framework 4/C# 关键字(非常用,持续更新...)
一、is 关键字 is 关键字用于检查对象是否于给定类型兼容,如果兼容将返回 true,如果不兼容则返回 false,在进行类型转换前,可以先使用 is 关键字判断对象是否与指定类型兼容,如果兼容才进行转换,这样的转换是安全的。 例如有:首先创建一个字符串对象,然后将字符串对象隐…...
AGain DB和倍数增益的关系
我在设置一款索尼CMOS芯片时,Again增益0db变化为6DB,画面的变化只有2倍DN的增益,比如10变为20。 这与dB和线性增益的关系以及传感器处理流程有关。以下是具体原因分析: 1. dB与线性增益的换算关系 6dB对应的理论线性增益应为&…...
免费PDF转图片工具
免费PDF转图片工具 一款简单易用的PDF转图片工具,可以将PDF文件快速转换为高质量PNG图片。无需安装复杂的软件,也不需要在线上传文件,保护您的隐私。 工具截图 主要特点 🚀 快速转换:本地转换,无需等待上…...
JS手写代码篇----使用Promise封装AJAX请求
15、使用Promise封装AJAX请求 promise就有reject和resolve了,就不必写成功和失败的回调函数了 const BASEURL ./手写ajax/test.jsonfunction promiseAjax() {return new Promise((resolve, reject) > {const xhr new XMLHttpRequest();xhr.open("get&quo…...
【前端异常】JavaScript错误处理:分析 Uncaught (in promise) error
在前端开发中,JavaScript 异常是不可避免的。随着现代前端应用越来越多地使用异步操作(如 Promise、async/await 等),开发者常常会遇到 Uncaught (in promise) error 错误。这个错误是由于未正确处理 Promise 的拒绝(r…...
