先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7
深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Web前端全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
如果你需要这些资料,可以添加V获取:vip1024c (备注前端)
正文
==============================================================
springboot内置了一些基本的CRUD方法,目的就是减少开发人员亲自去写sql语句,在了解springboot jpa的相关东西之前,有一个前置的知识就是spring mvc,其实也就是mvc模式,这个东西网上有很多资料,这里就不去介绍了。spring mvc中有一些概念controller
,service
,dao
,这三个是很重要概念,至于它们的概念和作用,同样网上很多资料。
简单的说就是:controller
是负责与前端对接并转发处理请求,最后把最终的处理结果返回给前端;service
负责进行业务的处理;dao
负责操作数据库;这三个各司其职能使项目结构清晰便于理解,同时降低代码的耦合。
一个完整的过程为:当一个前端请求过来后,首先进入的是controller
,controller
接收到之后,根据请求的路径进行匹配,匹配到之后执行关联的方法,而这个方法中则会调用service
的方法,service
的执行业务逻辑的操作,如果涉及到数据库的操作,则会调用dao
中的方法,这里的方法中就是对数据的操作了。重点来了:1、dao
中只要继承springboot的JpaRepository
接口,就能对数据库进行增删改查,无须自己写sql。2、dao
也可以通过@Query
注解自己去写sql实现对数据库的增删改查。
=================================================================
https://my.oschina.net/u/3080373/blog/1828589
jpa是一种规范,它通过注解或者XML描述【对象-关系表】之间的映射关系,并将实体对象持久化到数据库中
目的是让开发者从繁琐的JDBC和SQL代码中解脱出来。
JPA仅仅定义了一些接口,而接口是需要实现才能工作的。所以底层需要某种实现,而Hibernate就是实现了JPA接口的ORM框架
https://segmentfault.com/a/1190000021755149
我们原来使用JDBC连接来读写数据库,我们最常见的就是打开数据库连接、使用复杂的SQL语句进行读写、关闭连接,
获得的数据又需要转换或封装后往外传,这是一个非常烦琐的过程。这时出现了Hibernate框架,它需要你创建一系列的持久化类,
每个类的属性都可以简单的看做和一张数据库表的属性一一对应。这样我们不用在关注数据库,只需要持久化类就可以完成增删改查的功能。
使我们的软件开发真正面向对象, 而不是面向混乱的代码。
实体对象≠持久化对象。因为实体对象涵盖更广泛,它可以是持久化对象,也可以是内存中的任何对象。
======================================================================
简单的理解entity,就是一个实体类,一般对应数据库中一张表,那为什么要有这个东西?那么就反过来想,为什么继承了JpaRepository
接口就不用写sql了,没有这个bean(什么是bean上)(什么是bean下)告诉springboot在数据库有这么一张表,表里有这些字段,springboot怎么能对数据库的表进行增删改查呢。
===============================================================================
@RequestMapping()
就是用来解析url并映射到controller中的方法,如下
/**
-
模糊查询并分页
-
@param userName
-
@return
*/
@RequestMapping(value = “/getUserByNamePage”,params = {“userName”,“currentPage”,“pageSize”})
public List getUserByNamePage(@RequestParam String userName,int currentPage,int pageSize){
return userService.getUserByNamePage(userName,currentPage,pageSize);
}
当后端接收到请求http://localhost:8081/getUserByNamePage?userName=张三¤tPage=1&pageSize=10
之后,会解析这个url获得getUserByNamePage
这一段,那么就匹配上了@RequestMapping("/getUserByNamePage")
,然后开始执行getUserByNamePage()
这个方法。
@RequestParam
是获取路径上的请求参数,注意和@PathVariable()
不同,这个是获取path参数,比如这种/getXXX/{id}
@RequestBody
是获取body里的参数
@RequestMapping
的参数有value、method、params、headers、consumes、produces
value:就是请求的url
@RequestMapping(value=“/getXXX”)
打开全栈工匠技能包-1小时轻松掌握SSR
两小时精通jq+bs插件开发
生产环境下如歌部署Node.js
网易内部VUE自定义插件库NPM集成
谁说前端不用懂安全,XSS跨站脚本的危害
webpack的loader到底是什么样的?两小时带你写一个自己loader
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
的资料的朋友,可以添加V获取:vip1024c (备注前端)**
[外链图片转存中…(img-U4s1Z3ME-1713474347673)]
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!