当前位置: 首页 > news >正文

基于SpringBoot+Vue实现前后端交互功能(详解Vue框架机制)

目录

一、前言

Vue框架知多少?

Vue框架的一些关键特点:

Vue组件的声明周期

二、基于Spring Boot 和 Vue 实现前后端交互功能的技术组合

后端部分(Spring Boot):

前端部分(Vue):

前后端交互:


博主介绍:✌专注于前后端领域开发的优质创作者、秉着互联网精神开源贡献精神,答疑解惑、坚持优质作品共享。本人是掘金/腾讯云/阿里云等平台优质作者、擅长前后端项目开发和毕业项目实战,深受全网粉丝喜爱与支持✌有需要可以联系作者我哦!

🍅文末三连哦🍅

👇🏻 精彩专栏推荐订阅👇🏻 不然下次找不到哟

一、前言

Vue框架知多少?

Vue.js(通常简称为Vue)是一种流行的JavaScript前端框架,用于构建交互式的用户界面和单页面应用(SPA)。Vue由尤雨溪(Evan You)于2014年创建,并于同年正式发布。它的设计目标是通过尽可能简单的API提供高效的响应式数据绑定和组件化的视图组织方式。

Vue框架的一些关键特点:

  1. 响应式数据绑定:Vue使用双向数据绑定机制(通过指令v-model实现),当数据发生变化时,视图会自动更新,反之亦然。

  2. 组件化架构:Vue允许开发者将页面拆分为多个独立、可重用的组件,每个组件都有自己的状态和行为,从而更好地组织和管理UI代码。

  3. 虚拟DOM:Vue使用虚拟DOM技术来优化页面渲染性能,它会在内存中维护一份虚拟的DOM树,然后通过比对虚拟DOM和真实DOM的差异来最小化页面更新的开销。

  4. 单文件组件:Vue提供了单文件组件(.vue文件),允许开发者将组件的模板、样式和逻辑放在同一个文件中,使得组件的开发、维护和复用更加方便。

  5. 路由管理:Vue配合Vue Router可以实现客户端路由功能,允许开发者通过定义路由来管理不同页面的跳转和加载。

  6. 状态管理:Vue配合Vuex提供了一种集中式的状态管理解决方案,用于管理大型应用中的共享状态。

  7. 生命周期钩子:Vue组件具有一系列的生命周期钩子函数(如createdmountedupdated等),允许开发者在不同阶段执行自定义的逻辑。

Vue组件的声明周期

Vue.js 组件有一系列的生命周期钩子函数,它们提供了在组件生命周期不同阶段执行代码的机会。以下是 Vue 组件生命周期的主要钩子函数:

  1. beforeCreate

    • 在实例初始化之后,数据观测 (data observer) 和 event/watcher 事件配置之前被调用。
    • 在这个阶段,实例的属性和方法还未被初始化。
  2. created

    • 在实例创建完成后被立即调用。
    • 在这个阶段,实例已完成以下的配置:数据观测 (data observer),属性和方法的运算,watch/event 事件回调。
    • 然而,挂载阶段还未开始,$el 属性目前尚不可用。
  3. beforeMount

    • 在挂载开始之前被调用:相关的 render 函数首次被调用。
  4. mounted

    • 在挂载结束时调用:此时,实例已完成以下的配置:数据观测 (data observer),模板编译,挂载阶段完成。但是挂载的DOM还未更新。
  5. beforeUpdate

    • 在数据更新时调用,发生在虚拟 DOM 重新渲染和打补丁之前。
    • 这个阶段尚未更新DOM。
  6. updated

    • 在由于数据更改导致的 DOM 重新渲染和打补丁之后调用。
    • 调用时,组件 DOM 已经更新,所以您现在可以执行依赖于 DOM 的操作。但是要注意避免在此期间更改状态,因为这可能会导致无限循环。
  7. beforeDestroy

    • 在实例销毁之前调用。在这一步,实例仍然完全可用。
    • 该阶段常用于解绑定事件监听器或清除定时器。
  8. destroyed

    • 在实例销毁后调用。此时,所有的事件监听器都已被移除,所有的子实例也已经被销毁。

这些生命周期钩子为开发者提供了在不同阶段执行代码的机会,可以用来进行一些初始化操作、数据的处理、DOM的操作以及资源的清理。、

二、基于Spring Boot 和 Vue 实现前后端交互功能的技术组合

后端部分(Spring Boot):

  1. 创建Spring Boot项目:使用Spring Initializr创建一个新的Spring Boot项目,添加Web和其他必要的依赖。

  2. 编写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接口
    }
    
  3. Service层:编写Service层处理业务逻辑,如从数据库中获取数据。

  4. 数据模型:创建实体类来表示数据对象。

前端部分(Vue):

  1. 创建Vue项目:使用Vue CLI创建一个新的Vue项目。

  2. 编写组件:创建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>
    

  3. 路由:使用Vue Router进行页面路由管理。

  4. 样式:使用CSS或者其他CSS

    前后端交互:

  5. 跨域处理:在开发阶段,为了解决跨域问题,可以在Spring Boot中配置跨域访问:
  6. 预处理器(如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);}
    }
    
  7. 前端调用后端接口:在Vue组件中使用Fetch API或者Axios等工具来调用后端提供的API接口。

  8. 后端处理请求:Spring Boot中的Controller接收前端的请求,处理业务逻辑并返回数据。

  9. 前端处理响应:Vue组件中通过异步请求获取后端数据,然后更新页面。

  10. 错误处理:在前后端都要进行错误处理,例如前端可以通过axios的拦截器来统一处理错误信息,后端也应该在Controller中进行异常处理并返回合适的HTTP状态码。

相关文章:

基于SpringBoot+Vue实现前后端交互功能(详解Vue框架机制)

目录 一、前言 Vue框架知多少&#xff1f; Vue框架的一些关键特点&#xff1a; Vue组件的声明周期 二、基于Spring Boot 和 Vue 实现前后端交互功能的技术组合 后端部分&#xff08;Spring Boot&#xff09;&#xff1a; 前端部分&#xff08;Vue&#xff09;&#xff1a; 前后…...

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] 解码

题目描述 小明有一串很长的英文字母&#xff0c;可能包含大写和小写。 在这串字母中&#xff0c;有很多连续的是重复的。小明想了一个办法将这串字母表达得更短&#xff1a;将连续的几个相同字母写成字母 出现次数的形式。 例如&#xff0c;连续的 55 个 a&#xff0c;即 aa…...

开发npm上传发布

第一步&#xff1a;注册npm账号 首先去官网注册一个npm账号&#xff0c;npm官网 第二步&#xff1a;创建项目 新建文件夹&#xff0c;并执行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 # 必选&#xff0c;API 的版本号 kind: Pod # 必选&#xff0c;类型 Pod metadata: # 必选&#xff0c;元数据name: nginx # …...

js获取cookie

js获取cookie 前言实现讲解特别注意&#xff1a; 前言 主要是通过document.cookie来进行实现的 实现讲解 首先通过document.cookie 来获取到所有的cookie 然后通过分号进行分割成list 然后循环list,将list中的字符串通过首个等号进行分割然后和指定的cookie名进行比对然后返…...

RT Studio 仍存在的一些bug

年前有参加RT官方组织的活动&#xff0c;本来觉得是一路next的使用体验所以就没有提前跑一遍&#xff0c;然后现场做实验的时候&#xff0c;尴尬了。 安装官方guide&#xff0c;下载工具链&#xff0c;下载bsp&#xff0c;新建开发板项目&#xff0c;下载软件组件&#xff0c;全…...

[flask]cookie的基本使用/

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

【Linux中vim系列】如何在vim中检索字符串

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐: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)——页面布局方法

瀑布流 优点&#xff1a;节省空间&#xff0c;外表美观&#xff0c;更有艺术性 对于触屏设备非常友好&#xff0c;通过向上滑动浏览 用户浏览时的观赏和思维不容易被打断&#xff0c;留存更容易 缺点&#xff1a;用户…...

06|Java集合框架初学者指南:List、Set与Map的实战训练

Java集合框架是Java语言的核心部分,它提供了丰富的类和接口,用来高效地管理和操作大量数据。这个强大的工具箱包括多种集合类型,其中最为常用的是List、Set和Map。 1.List - 有序且可重复的数据清单 概念: List就像一个购物清单,你可以按照加入顺序存放和检索项目,而且同…...

Jmeter基础篇(18)压测过程中的注意事项

一、测试计划设计&#xff1a; 1、场景设计&#xff1a;需要基于实际业务需求设计合理的并发用户模型、事务和思考时间&#xff0c;模拟真实用户的操作行为。 2、目标明确&#xff1a;定义明确的性能指标&#xff08;如响应时间、吞吐量、并发用户数、错误率等&#xff09;和性…...

‘npm‘ 不是内部或外部命令,也不是可运行的程序

npm认识三年了&#xff0c;今天才知道这是node.js的命令 也就是说&#xff0c;想要在cmd里面运行 npm 命令&#xff0c;但就的安装node.js 1. node.js安装 没有安装包的先下载安装包&#xff1a;下载 | Node.js 中文网 (nodejs.cn) 下载之后双击打开&#xff0c;一路安装确…...

使el-table通过操控鼠标滚轮横向滚动

1.创建directive文件夹&#xff0c;里面创建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…...

神经网络深度学习梯度下降算法优化

【神经网络与深度学习】以最通俗易懂的角度解读[梯度下降法及其优化算法]&#xff0c;这一篇就足够&#xff08;很全很详细&#xff09;_梯度下降在神经网络中的作用及概念-CSDN博客 https://blog.51cto.com/u_15162069/2761936 梯度下降数学原理...

向开发板上移植ip工具:将ip工具移植到开发板系统中

一. 简介 前面一篇文章对 ip工具源码进行了交叉编译&#xff0c;生成了ip工具。文章如下&#xff1a; 向开发板上移植ip工具&#xff1a;交叉编译 ip工具-CSDN博客 本文对生成的 ip工具进行移植&#xff0c;即移植到开发板系统中&#xff0c;并确定是否可用。 二. 向开发板…...

数据关联_3.7

目标 利用匈牙利算法对目标框和检测框进行关联 在这里我们对检测框和跟踪框进行匹配&#xff0c;整个流程是遍历检测框和跟踪框&#xff0c;并进行匹配&#xff0c;匹配成功的将其保留&#xff0c;未成功的将其删除。 def associate_detections_to_trackers(detections, track…...

总结虚函数表机制——c++多态底层原理

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

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…...

谷歌浏览器插件

项目中有时候会用到插件 sync-cookie-extension1.0.0&#xff1a;开发环境同步测试 cookie 至 localhost&#xff0c;便于本地请求服务携带 cookie 参考地址&#xff1a;https://juejin.cn/post/7139354571712757767 里面有源码下载下来&#xff0c;加在到扩展即可使用FeHelp…...

设计模式和设计原则回顾

设计模式和设计原则回顾 23种设计模式是设计原则的完美体现,设计原则设计原则是设计模式的理论基石, 设计模式 在经典的设计模式分类中(如《设计模式:可复用面向对象软件的基础》一书中),总共有23种设计模式,分为三大类: 一、创建型模式(5种) 1. 单例模式(Sing…...

突破不可导策略的训练难题:零阶优化与强化学习的深度嵌合

强化学习&#xff08;Reinforcement Learning, RL&#xff09;是工业领域智能控制的重要方法。它的基本原理是将最优控制问题建模为马尔可夫决策过程&#xff0c;然后使用强化学习的Actor-Critic机制&#xff08;中文译作“知行互动”机制&#xff09;&#xff0c;逐步迭代求解…...

VB.net复制Ntag213卡写入UID

本示例使用的发卡器&#xff1a;https://item.taobao.com/item.htm?ftt&id615391857885 一、读取旧Ntag卡的UID和数据 Private Sub Button15_Click(sender As Object, e As EventArgs) Handles Button15.Click轻松读卡技术支持:网站:Dim i, j As IntegerDim cardidhex, …...

IGP(Interior Gateway Protocol,内部网关协议)

IGP&#xff08;Interior Gateway Protocol&#xff0c;内部网关协议&#xff09; 是一种用于在一个自治系统&#xff08;AS&#xff09;内部传递路由信息的路由协议&#xff0c;主要用于在一个组织或机构的内部网络中决定数据包的最佳路径。与用于自治系统之间通信的 EGP&…...

基于Flask实现的医疗保险欺诈识别监测模型

基于Flask实现的医疗保险欺诈识别监测模型 项目截图 项目简介 社会医疗保险是国家通过立法形式强制实施&#xff0c;由雇主和个人按一定比例缴纳保险费&#xff0c;建立社会医疗保险基金&#xff0c;支付雇员医疗费用的一种医疗保险制度&#xff0c; 它是促进社会文明和进步的…...

【网络安全产品大调研系列】2. 体验漏洞扫描

前言 2023 年漏洞扫描服务市场规模预计为 3.06&#xff08;十亿美元&#xff09;。漏洞扫描服务市场行业预计将从 2024 年的 3.48&#xff08;十亿美元&#xff09;增长到 2032 年的 9.54&#xff08;十亿美元&#xff09;。预测期内漏洞扫描服务市场 CAGR&#xff08;增长率&…...

Opencv中的addweighted函数

一.addweighted函数作用 addweighted&#xff08;&#xff09;是OpenCV库中用于图像处理的函数&#xff0c;主要功能是将两个输入图像&#xff08;尺寸和类型相同&#xff09;按照指定的权重进行加权叠加&#xff08;图像融合&#xff09;&#xff0c;并添加一个标量值&#x…...

【AI学习】三、AI算法中的向量

在人工智能&#xff08;AI&#xff09;算法中&#xff0c;向量&#xff08;Vector&#xff09;是一种将现实世界中的数据&#xff08;如图像、文本、音频等&#xff09;转化为计算机可处理的数值型特征表示的工具。它是连接人类认知&#xff08;如语义、视觉特征&#xff09;与…...