概述

WebJars是一个很神奇的东西,可以让大家以jar包的形式来使用前端的各种框架、组件。

什么是WebJars

什么是WebJars?WebJars是将客户端(浏览器)资源(JavaScript,Css等)打成jar包文件,以对资源进行统一依赖管理。WebJars的jar包部署在Maven中央仓库上。

为什么使用

我们在开发Java web项目的时候会使用像Maven,Gradle等构建工具以实现对jar包版本依赖管理,以及项目的自动化管理,但是对于JavaScript,Css等前端资源包,我们只能采用拷贝到webapp下的方式,这样做就无法对这些资源进行依赖管理。那么WebJars就提供给我们这些前端资源的jar包形势,我们就可以进行依赖管理。

如何使用

1、 WebJars主官网 查找对于的组件,比如jquery

<dependency>
    <groupId>org.webjars.bower</groupId>
    <artifactId>jquery</artifactId>
    <version>3.3.1</version>
</dependency>

2、页面引入

<link th:href="@{/webjars/jquery/3.3.1/jquery.js}" rel="stylesheet"></link>

就可以正常使用了!

像上面的每个引用文件里都要带一个版本,假如项目要升级,那得麻烦死去啊,有木有更好的办法呢?

添加版本定位工具

<dependency>
     <groupId>org.webjars</groupId>
     <artifactId>webjars-locator-core</artifactId>
</dependency>

这样之后页面引入就变成这样了

<link th:href="@{/webjars/jquery/jquery.js}" rel="stylesheet"></link>
总结

使用WebJars对前端依赖进行统一管理有什么好处呢?

  1. 静态资源版本化

传统的静态资源需要自行维护,资源种类繁多,使得项目后期越来越臃肿,维护版本升级也变得困难,而使用WebJars方式进行管理后,版本升级问题迎刃而解。

  1. 提升编译速度

经测试,使用WebJars的方式管理依赖可以给项目的编译速度带来2-5倍的速度提升,还在犹豫的小伙伴快点尝试起来吧!

  1. 在WebJars官方找不到自己想要的依赖怎么办?

将下载好的静态资源目录发布到公司私服仓库即可。 例如:新建一个SpringBoot项目,手工创建目录 META-INF/resources/ ,将静态资源完整复制进去,然后发布公司Maven私服即可