前言
你好,我是A哥(YourBatman)。
如何给Module模块单独增加依赖?
如何知道哪些Module模块用了Spring框架,哪些是web工程?
IDEA如何打Jar包?打War包?
熟练的正确使用IntelliJ IDEA,是一个“高手”该有的样子,因为那是你的门面。上篇文章 重点介绍了IDEA里最为重要的两个概念:Project项目和Module模块。相信你看完后再也不会把IDEA的Project比作Eclipse的Workspace,并且对IDEA有了一份更深的了解。
本文继续理解IDEA对项目、模块的管理。管理项目是一个IDE的基本功能,但往往最基础的是最重要的更是最容易被忽略的。因此本文是你更好去理解IDEA管理maven结构、gradle结构、Spring Boot项目结构的基础,万丈高楼平地起,它就是这个地基。上层结构再怎么繁繁多变,殊途同归最终都由Project Structure来体现,从而给开发者以几近相同的编码体验。
本文提纲
版本约定
IntelliJ IDEA:2020.3.1
正文
Project Structure是一个你开发过程中偶尔/经常会打开,但却很少用心留意的窗口。不同于一般设置窗口,它和项目的紧密度非常的高且有一定理解难度,若设置不当项目可能无法运行甚至无法编码(比如编译报错、jar包找不着等),为此我做件一般人都不愿意做的事,对它进行详解,相信做难事必有所得。
本文基于上文已搭建好的hello项目案例,继续研究其项目结构Project Structure的管理。从结构查看,到修改定制,那么问题来了,如何打开一个Project项目的结构页呢?
如何打开Project Structure?
看似一个简单的操作,里面其实蕴藏着你对IDEA Project和Module的理解,否则势必不知从哪下手。据了解,也许你是多年的程序员,也未必知道从哪下手。
按照一般思维,会鼠标选中hello,然后右键:
但对不起,右键菜单里并无Project Structure选项。Project Structure顾名思义,是针对Project维度的结构视窗,而你鼠标选中的hello只是个module,所以自然弹出的是对此module的操作菜单喽,而非Project的。也许你可能会讲:我点击了Open Module Settings也打开了Project Structure视窗呀,是的效果上你可能是打开了但道理并非如此,而仅仅是因为把它俩放在了一起(同一视窗)而已。
说明:理解IDEA的Project和Module两大概念,是对IDEA进行一切操作的基础。前文已非常详细(可能是全网最全)的介绍了它俩,可花几分钟前往学习。点这里电梯直达
三种打开方式
要打开一个Project的结构展示窗口,至少有如下三种办法,本文都例举给你。
- 顶部菜单File -> Project Structure
2.点击右上角的快捷按钮
3.快捷键方式(推荐)
这是我本人最喜欢的方式,至于快捷键是哪个就看你是如何设定的喽,我的快捷键是ctrl + shift + alt + s。
啰嗦一句:建议你操作IDEA多用快捷键,那会大大提高编码的效率,并且看起来像高手。基本上记住50个左右快捷键就够用了,长期以往成了肌肉记忆后这就是你的核心竞争力之一了
打开hello项目的结构页如下图所示:
解释:为何不需要鼠标选中项目?
对于这个动作,敏感的你是否有发现:打开项目结构并不需要鼠标选中任何东西(快捷键随意使用),也就是说鼠标失焦状态都没问题,何解呢?
回答这个问题并不难,前提是你已经对IDEA的Project概念烂熟于胸。一个Project对应一个视窗,它们是严格1:1的关系。换句话讲,当前视窗就代表着Project,因此操作本视窗顶部菜单栏就肯定是作用在该Project上,又何须专门选中什么呢?再者,Project只是个逻辑概念,你想选都没得选中的,所以把视窗当作它就好。有没有觉得,这和Java中的this关键字调用特别像?
最后,这个问题的答案是:只要鼠标还在IDEA视窗内(该视窗是活跃窗口),那么对Project就永远就是“选中”状态。
Project Structure项目结构剖析
项目结构视窗已打开,那接下来重点来喽。可以看到它左边的“菜单栏”,共分为三个part:
- Project Settings:项目设置(最重要),本文详解
- Platform Settings:平台设置,也叫全局设置。用于管理SDK们(如JDK、Kotlin的SDK等)、全局库。
- 一般来讲,全局的JDK都会配置在此处,比如我因为经常要做多版本尝试,就管理了多个JDK版本
- Problems:问题。一般项目出现了问题都会在此体现(如依赖不一致问题等等),总之问题数量一致让它是0是最优的
其中Project Settings里面的每个标签页是最常用,最关心的。下面就对它的每个tab页作出解释和使用说明。
Project页情况
此视窗可以看到Project本身的基础信息。如:名称、SDK版本、语言等级等等,比较简单。
对于此页面的元素,多啰嗦几句:
1.为何是SDK版本而不是JDK版本?答:因为IntelliJ IDEA是JVM平台IDEA,不仅仅支持Java还有其它语言如Kotlin,所以写成SDK更抽象
2.为何指定了SDK还要指定语言等级?答:因为SDK版本并不直接决定语言等级。如你用的JDK 11,但依旧可以把语言等级调为8来进行编译/运行
1.这是集成开发环境的优势所在,轻松对多环境进行定制化支持
3.SDK和语言等级Project都可指定,作为全局默认
1.这些配置Module默认集成,但可自行修改自己的。比如module 1使用Java 5编译,module 2使用Java 11编译,这是允许的
Module页情况
Module页可谓是重点中的重点,甚至是最重要。毕竟Module作为实际存在形式,所有的源代码、配置、依赖等都在这里,因此大有可学呀。
值得注意:Tests测试包里面的是可以访问Sources源码的,但反过来不行。
每个模块都能独立管理着自己的依赖,这种关系在模块自己的.iml文件中记录着。
知识点:
- Project创建时默认会创建一个同名的Module模块
- Module默认沿用Project的SDK、语言等级等设置,当然也可自己指定
- 每个Module可自行管理依赖,可以是二方库、三方库…
- 本模块的依赖情况默认存储在项目的{moduleName}.iml文件里
新增依赖
既然Module可以自行管理依赖,那么如何给该模块新增依赖呢?
举个例子,现在需要向hello模块增加一个commons-io jar包依赖,可以点击Dependencies标签页左下角的+号,选择Library:
然后选择,如果没有就选择New Libarary...创建一个呗(有就直接用就成):
下面分别演示选择Java和选择From Maven两种不同库的方式: