maven构件子模块步骤及注意事项

一、创建父工程

父工程可以是顶级父工程,也可以是在父工程下,父工程的packaging需要设置为pom;父工程下的子级父工程,主要作用是模块聚合,即继承父工程和modules聚合,没有src文件,pom文件也不做依赖版本控制

XML 复制代码
  <!--父工程的packaging都是pom,无论是顶级父工程还是模块的父工程    -->
    <packaging>pom</packaging>

二、在子工程中引入parent

XML 复制代码
    <parent>
        <groupId>com.xuecheng</groupId>
        <artifactId>xuecheng-plus-parent</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <!--基于当前pom.xml找到父工程,   ../上一级目录-->
        <relativePath>../xuecheng-plus-parent</relativePath>
    </parent>

如果该工程是父工程的平级工程(即父工程和子工程的文件夹均在同一个目录下),则需要显示指出父工程的pom.xml的位置(如上所示../表示上一级目录),如果是平级工程则不需要,可以省略relativePath标签

三、在父工程中添加modules标签,说明子工程

XML 复制代码
    <modules>
        <module>xuecheng-plus-content-api</module>
        <module>xuecheng-plus-content-model</module>
        <module>xuecheng-plus-content-service</module>
    </modules>

此标签在父工程的pom.xml中表示子模块的位置,标签内元素为<module>。以当前父工程所在的文件夹为基准,<module>中填写子模块的相对路径;

如果是父工程文件夹下的子工程,则直接填写其文件夹名即可

四、子工程之间的相互调用,通过添加依赖实现,并且依赖可以传递

XML 复制代码
<!--  api依赖service,service依赖model,model依赖base,base依赖parent,依赖传递-->
        <dependency>
            <groupId>com.xuecheng</groupId>
            <artifactId>xuecheng-plus-content-service</artifactId>
            <version>0.0.1-SNAPSHOT</version>
        </dependency>
相关推荐
蓝婷儿几秒前
每天一个前端小知识 Day 21 - 浏览器兼容性与 Polyfill 策略
前端
百锦再3 分钟前
Vue中对象赋值问题:对象引用被保留,仅部分属性被覆盖
前端·javascript·vue.js·vue·web·reactive·ref
jingling5557 分钟前
面试版-前端开发核心知识
开发语言·前端·javascript·vue.js·面试·前端框架
拾光拾趣录12 分钟前
CSS 深入解析:提升网页样式技巧与常见问题解决方案
前端·css
莫空000013 分钟前
深入理解JavaScript属性描述符:从数据属性到存取器属性
前端·面试
guojl14 分钟前
深度剖析Kafka读写机制
前端
guojl14 分钟前
深度解读jdk8 HashMap设计与源码
java
FogLetter15 分钟前
图片懒加载:让网页飞起来的魔法技巧 ✨
前端·javascript·css
Mxuan15 分钟前
vscode webview 插件开发(精装篇)
前端
Mxuan16 分钟前
vscode webview 插件开发(交付篇)
前端