基于SpringBoot+Vue实现前后端交互功能(详解Vue框架机制)
目录
一、前言
Vue框架知多少?
Vue框架的一些关键特点:
Vue组件的声明周期
二、基于Spring Boot 和 Vue 实现前后端交互功能的技术组合
后端部分(Spring Boot):
前端部分(Vue):
前后端交互:
博主介绍:✌专注于前后端领域开发的优质创作者、秉着互联网精神开源贡献精神,答疑解惑、坚持优质作品共享。本人是掘金/腾讯云/阿里云等平台优质作者、擅长前后端项目开发和毕业项目实战,深受全网粉丝喜爱与支持✌有需要可以联系作者我哦!
🍅文末三连哦🍅
👇🏻 精彩专栏推荐订阅👇🏻 不然下次找不到哟
一、前言
Vue框架知多少?
Vue.js(通常简称为Vue)是一种流行的JavaScript前端框架,用于构建交互式的用户界面和单页面应用(SPA)。Vue由尤雨溪(Evan You)于2014年创建,并于同年正式发布。它的设计目标是通过尽可能简单的API提供高效的响应式数据绑定和组件化的视图组织方式。
Vue框架的一些关键特点:
-
响应式数据绑定:Vue使用双向数据绑定机制(通过指令
v-model
实现),当数据发生变化时,视图会自动更新,反之亦然。 -
组件化架构:Vue允许开发者将页面拆分为多个独立、可重用的组件,每个组件都有自己的状态和行为,从而更好地组织和管理UI代码。
-
虚拟DOM:Vue使用虚拟DOM技术来优化页面渲染性能,它会在内存中维护一份虚拟的DOM树,然后通过比对虚拟DOM和真实DOM的差异来最小化页面更新的开销。
-
单文件组件:Vue提供了单文件组件(.vue文件),允许开发者将组件的模板、样式和逻辑放在同一个文件中,使得组件的开发、维护和复用更加方便。
-
路由管理:Vue配合Vue Router可以实现客户端路由功能,允许开发者通过定义路由来管理不同页面的跳转和加载。
-
状态管理:Vue配合Vuex提供了一种集中式的状态管理解决方案,用于管理大型应用中的共享状态。
-
生命周期钩子:Vue组件具有一系列的生命周期钩子函数(如
created
、mounted
、updated
等),允许开发者在不同阶段执行自定义的逻辑。
Vue组件的声明周期
Vue.js 组件有一系列的生命周期钩子函数,它们提供了在组件生命周期不同阶段执行代码的机会。以下是 Vue 组件生命周期的主要钩子函数:
-
beforeCreate:
- 在实例初始化之后,数据观测 (data observer) 和 event/watcher 事件配置之前被调用。
- 在这个阶段,实例的属性和方法还未被初始化。
-
created:
- 在实例创建完成后被立即调用。
- 在这个阶段,实例已完成以下的配置:数据观测 (data observer),属性和方法的运算,watch/event 事件回调。
- 然而,挂载阶段还未开始,$el 属性目前尚不可用。
-
beforeMount:
- 在挂载开始之前被调用:相关的 render 函数首次被调用。
-
mounted:
- 在挂载结束时调用:此时,实例已完成以下的配置:数据观测 (data observer),模板编译,挂载阶段完成。但是挂载的DOM还未更新。
-
beforeUpdate:
- 在数据更新时调用,发生在虚拟 DOM 重新渲染和打补丁之前。
- 这个阶段尚未更新DOM。
-
updated:
- 在由于数据更改导致的 DOM 重新渲染和打补丁之后调用。
- 调用时,组件 DOM 已经更新,所以您现在可以执行依赖于 DOM 的操作。但是要注意避免在此期间更改状态,因为这可能会导致无限循环。
-
beforeDestroy:
- 在实例销毁之前调用。在这一步,实例仍然完全可用。
- 该阶段常用于解绑定事件监听器或清除定时器。
-
destroyed:
- 在实例销毁后调用。此时,所有的事件监听器都已被移除,所有的子实例也已经被销毁。
这些生命周期钩子为开发者提供了在不同阶段执行代码的机会,可以用来进行一些初始化操作、数据的处理、DOM的操作以及资源的清理。、
二、基于Spring Boot 和 Vue 实现前后端交互功能的技术组合
后端部分(Spring Boot):
-
创建Spring Boot项目:使用Spring Initializr创建一个新的Spring Boot项目,添加Web和其他必要的依赖。
-
编写Controller:在Spring Boot项目中创建RESTful API的Controller,用于处理前端的请求和响应数据。
@RestController @RequestMapping("/api") public class ApiController {@Autowiredprivate YourService yourService;@GetMapping("/data")public ResponseEntity<?> fetchData() {// 从数据库或其他数据源获取数据List<Data> dataList = yourService.fetchData();return ResponseEntity.ok(dataList);}// 可以添加其他需要的API接口 }
-
Service层:编写Service层处理业务逻辑,如从数据库中获取数据。
-
数据模型:创建实体类来表示数据对象。
前端部分(Vue):
-
创建Vue项目:使用Vue CLI创建一个新的Vue项目。
-
编写组件:创建Vue组件来渲染页面和处理用户交互。
<template><div><ul><li v-for="item in dataList" :key="item.id">{{ item.name }}</li></ul></div> </template><script> export default {data() {return {dataList: []};},created() {this.fetchData();},methods: {fetchData() {// 从后端获取数据fetch('/api/data').then(response => response.json()).then(data => {this.dataList = data;}).catch(error => console.error('Error:', error));}} }; </script>
-
路由:使用Vue Router进行页面路由管理。
-
样式:使用CSS或者其他CSS
前后端交互:
- 跨域处理:在开发阶段,为了解决跨域问题,可以在Spring Boot中配置跨域访问:
-
预处理器(如Sass或Less)来编写样式。
@Configuration public class WebConfig implements WebMvcConfigurer {@Overridepublic void addCorsMappings(CorsRegistry registry) {registry.addMapping("/api/**").allowedOrigins("http://localhost:8080").allowedMethods("GET", "POST", "PUT", "DELETE").allowCredentials(true).maxAge(3600);} }
-
前端调用后端接口:在Vue组件中使用Fetch API或者Axios等工具来调用后端提供的API接口。
-
后端处理请求:Spring Boot中的Controller接收前端的请求,处理业务逻辑并返回数据。
-
前端处理响应:Vue组件中通过异步请求获取后端数据,然后更新页面。
-
错误处理:在前后端都要进行错误处理,例如前端可以通过axios的拦截器来统一处理错误信息,后端也应该在Controller中进行异常处理并返回合适的HTTP状态码。
相关文章:
基于SpringBoot+Vue实现前后端交互功能(详解Vue框架机制)
目录 一、前言 Vue框架知多少? Vue框架的一些关键特点: Vue组件的声明周期 二、基于Spring Boot 和 Vue 实现前后端交互功能的技术组合 后端部分(Spring Boot): 前端部分(Vue): 前后…...
go的Job Scheduling
背景 司内线上服务有很多异步脚本,大量冗余代码,管理很不方便 急需一个美丽的框架,让代码变得美好 包 go get github.com/go-co-op/gocron/v2 介绍 gocron is a job scheduling package which lets you run Go functions at pre-determined intervals. 概念 Job Job封…...
[蓝桥杯 2020 省 AB1] 解码
题目描述 小明有一串很长的英文字母,可能包含大写和小写。 在这串字母中,有很多连续的是重复的。小明想了一个办法将这串字母表达得更短:将连续的几个相同字母写成字母 出现次数的形式。 例如,连续的 55 个 a,即 aa…...
开发npm上传发布
第一步:注册npm账号 首先去官网注册一个npm账号,npm官网 第二步:创建项目 新建文件夹,并执行npm init 填写对应的信息name就是插件名称。 文件夹下就会生成一个package.json文件。 你可以在项目编辑你的插件。 第三步&…...
c语音函数大全(U开头)
c语音函数大全(U开头) There is no nutrition in the blog content. After reading it, you will not only suffer from malnutrition, but also impotence. The blog content is all parallel goods. Those who are worried about being cheated should leave quickly. 函数名…...

飞天使-k8s知识点26-kubernetes温故知新1-pod
文章目录 创建一个podpod的启动命令和参数更改pod 镜像拉取策略 pod 的三种探针pod 探针的实现方式prestop 和 prestart 创建一个pod apiVersion: v1 # 必选,API 的版本号 kind: Pod # 必选,类型 Pod metadata: # 必选,元数据name: nginx # …...

js获取cookie
js获取cookie 前言实现讲解特别注意: 前言 主要是通过document.cookie来进行实现的 实现讲解 首先通过document.cookie 来获取到所有的cookie 然后通过分号进行分割成list 然后循环list,将list中的字符串通过首个等号进行分割然后和指定的cookie名进行比对然后返…...
RT Studio 仍存在的一些bug
年前有参加RT官方组织的活动,本来觉得是一路next的使用体验所以就没有提前跑一遍,然后现场做实验的时候,尴尬了。 安装官方guide,下载工具链,下载bsp,新建开发板项目,下载软件组件,全…...

[flask]cookie的基本使用/
彻底理解 Cookie - 知乎 (zhihu.com) 是什么 cookie是当你浏览某个网站的时候,由web服务器存储在你的机器硬盘上的一个小的文本文件。它其中记录了你的用户名、密码、浏览的网页、停留的时间等等信息。当你再次来到这个网站时,web服务器会先看看有没有…...

【Linux中vim系列】如何在vim中检索字符串
💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…...

python、execl数据分析(数据描述)
一 python 1.各函数 1.1python库的安装与导入 #pip install os#pip install matplotlib#pip install seaborn#pip install scikit-learn#pip install scipy#修 改 工 作 目 录import osos.getcwd () # 查看当前工作环境os.chdir( F :\my course\database ) # 修改工作环境o…...
前端理论总结(css3)——页面布局方法
瀑布流 优点:节省空间,外表美观,更有艺术性 对于触屏设备非常友好,通过向上滑动浏览 用户浏览时的观赏和思维不容易被打断,留存更容易 缺点:用户…...
06|Java集合框架初学者指南:List、Set与Map的实战训练
Java集合框架是Java语言的核心部分,它提供了丰富的类和接口,用来高效地管理和操作大量数据。这个强大的工具箱包括多种集合类型,其中最为常用的是List、Set和Map。 1.List - 有序且可重复的数据清单 概念: List就像一个购物清单,你可以按照加入顺序存放和检索项目,而且同…...
Jmeter基础篇(18)压测过程中的注意事项
一、测试计划设计: 1、场景设计:需要基于实际业务需求设计合理的并发用户模型、事务和思考时间,模拟真实用户的操作行为。 2、目标明确:定义明确的性能指标(如响应时间、吞吐量、并发用户数、错误率等)和性…...

‘npm‘ 不是内部或外部命令,也不是可运行的程序
npm认识三年了,今天才知道这是node.js的命令 也就是说,想要在cmd里面运行 npm 命令,但就的安装node.js 1. node.js安装 没有安装包的先下载安装包:下载 | Node.js 中文网 (nodejs.cn) 下载之后双击打开,一路安装确…...
使el-table通过操控鼠标滚轮横向滚动
1.创建directive文件夹,里面创建directive.js文件 import Vue from vue;Vue.directive(scroll-x,{inserted:function(el){let domClass el.getAttribute(class)if(domClass.indexOf(el-table)<0){return false}const scrollDiv el;if(scrollDivnull){return fa…...
神经网络深度学习梯度下降算法优化
【神经网络与深度学习】以最通俗易懂的角度解读[梯度下降法及其优化算法],这一篇就足够(很全很详细)_梯度下降在神经网络中的作用及概念-CSDN博客 https://blog.51cto.com/u_15162069/2761936 梯度下降数学原理...
向开发板上移植ip工具:将ip工具移植到开发板系统中
一. 简介 前面一篇文章对 ip工具源码进行了交叉编译,生成了ip工具。文章如下: 向开发板上移植ip工具:交叉编译 ip工具-CSDN博客 本文对生成的 ip工具进行移植,即移植到开发板系统中,并确定是否可用。 二. 向开发板…...
数据关联_3.7
目标 利用匈牙利算法对目标框和检测框进行关联 在这里我们对检测框和跟踪框进行匹配,整个流程是遍历检测框和跟踪框,并进行匹配,匹配成功的将其保留,未成功的将其删除。 def associate_detections_to_trackers(detections, track…...

总结虚函数表机制——c++多态底层原理
前言: 前几天学了多态。 然后过去几天一直在测试多态的底层与机制。今天将多态的机制以及它的本质分享给受多态性质困扰的友友们。 本节内容只涉及多态的原理, 也就是那张虚表的规则,有点偏向底层。 本节不谈语法!不谈语法&#x…...

2024年第十五届蓝桥杯青少组c++国赛真题——快速分解质因数
2024年第十五届蓝桥杯青少组c国赛真题——快速分解质因数 题目可点下方去处,支持在线编程,在线测评~ 快速分解质因数_C_少儿编程题库学习中心-嗨信奥 题库收集了历届各白名单赛事真题和权威机构考级真题,覆盖初赛—省赛—国赛&am…...
转战web3远程工作的英语学习的路线规划
目录 一、明确学习目标与定位 二、基础阶段(0 - 6个月) (一)词汇积累 (二)语法学习 (三)听力与口语 三、进阶阶段(6 - 18个月) (一…...

Kafka深度技术解析:架构、原理与最佳实践
一、 消息队列的本质价值与核心特性 1.1 分布式系统的“解耦器” 异步通信模型 代码列表 graph LRA[生产者] -->|异步推送| B[(消息队列)]B -->|按需拉取| C[消费者1]B -->|按需拉取| D[消费者2] 生产者发送后立即返回,消费者以自己的节奏处理消息。典…...
纹理压缩格式优化
🎯 Unity 项目纹理压缩格式优化终极指南 ——不同平台、不同手机型号,如何正确选择 🧩 什么是纹理压缩(Texture Compression)? Texture压缩 = 减小显存占用,提升加载速度,减轻GPU负担纹理是游戏中最大资源,占用50%+内存正确压缩:减少GPU Bandwidth,提高渲染性能错…...

【HarmonyOS Next之旅】DevEco Studio使用指南(三十)
目录 1 -> 部署云侧工程 2 -> 通过CloudDev面板获取云开发资源支持 3 -> 通用云开发模板 3.1 -> 适用范围 3.2 -> 效果图 4 -> 总结 1 -> 部署云侧工程 可以选择在云函数和云数据库全部开发完成后,将整个云工程资源统一部署到AGC云端。…...
#Java篇:学习node后端之sql常用操作
学习路线 1、javascript基础; 2、nodejs核心模块 fs: 文件系统操作 path: 路径处理 http / https: 创建服务器或发起请求 events: 事件机制(EventEmitter) stream: 流式数据处理 buffer: 处理二进制数据 os: 获取操作系统信息 util: 工具方…...

ck-editor5的研究 (2):对 CKEditor5 进行设计,并封装成一个可用的 vue 组件
前言 在上一篇文章中—— ck-editor5的研究(1):快速把 CKEditor5 集成到 nuxt 中 ,我仅仅是把 ckeditor5 引入到了 nuxt 中,功能还不算通用。 这一篇内容将会对其进行设计,并封装成可复用的 vue 组件&…...

消费者行为变革下开源AI智能名片与链动2+1模式S2B2C商城小程序的协同创新路径
摘要:在信息爆炸与消费理性化趋势下,消费者从被动接受转向主动筛选,企业营销模式面临重构挑战。本文提出开源AI智能名片与链动21模式S2B2C商城小程序的协同创新框架,通过AI驱动的精准触达、链动裂变机制与S2B2C生态赋能࿰…...

C语言 — 动态内存管理
目录 1.malloc和free函数1.1 malloc函数1.2 free函数1.3 malloc函数的使用 2.calloc函数2.1 calloc函数2.2 calloc函数的使用 3.realloc函数3.1 realloc函数3.2 realloc函数的使用 4.动态内存管理笔试题4.1 笔试题(1)4.2 笔试题(2)…...
Go Modules 详解 -《Go语言实战指南》
Go Modules(简称 go mod)是 Go 官方推出的包依赖管理系统,自 Go 1.11 起引入,Go 1.16 起成为默认方式,取代了旧的 GOPATH 模式。 本章将全面讲解 Go Modules 的基本原理、使用方法以及常见问题处理。 一、Go Modules 简…...