将本地依赖包也一同打包

首先,你需要新建一个assembly.xml文件,路径可以随意,然后填入以下内容:

<?xml version="1.0" encoding="UTF-8"?>
<assembly>
    <id>jar-with-dependencies</id>
    <formats>
        <format>jar</format>
    </formats>
    <includeBaseDirectory>false</includeBaseDirectory>
    <dependencySets>
        <!-- 默认的配置 -->
        <dependencySet>
            <outputDirectory>/</outputDirectory>
            <useProjectArtifact>true</useProjectArtifact>
            <unpack>true</unpack>
            <scope>runtime</scope>
        </dependencySet>
        <!-- 增加scope类型为system的配置 -->
        <dependencySet>
            <outputDirectory>/</outputDirectory>
            <useProjectArtifact>true</useProjectArtifact>
            <unpack>true</unpack>
            <scope>system</scope>
        </dependencySet>
    </dependencySets>
</assembly>

接着,你的pom.xml的build配置也需要进行相应的修改

<build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.3</version>
                <configuration>
                    <source>${maven.compile.source}</source>
                    <target>${maven.compile.target}</target>
                    <encoding>${project.build.sourceEncoding}</encoding>
                </configuration>
            </plugin>
          
            <plugin>
                <artifactId>maven-assembly-plugin</artifactId>
                <configuration>
                    <archive>
                        <manifest>
                            <mainClass>com.quan.simple.IncFrame</mainClass>
                        </manifest>
                        <manifestEntries>
                            <Class-Path>.</Class-Path>
                        </manifestEntries>
                    </archive>
                </configuration>
                <executions>
                    <execution>
                        <id>make-assembly</id>
                        <phase>package</phase>
                        <goals>
                            <goal>single</goal>
                        </goals>
                        <configuration>
                            <descriptors>
                                <descriptor>assembly.xml</descriptor>
                            </descriptors>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

容易疏忽的一点,在前面的plugins中加上

<plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <version>2.1.1.RELEASE</version>
                <configuration>
                       //这一行一定要加
                    <includeSystemScope>true</includeSystemScope>
                    <excludes>
                        <exclude>
                            <groupId>org.projectlombok</groupId>
                            <artifactId>lombok</artifactId>
                        </exclude>
                    </excludes>
                    <fork>true</fork> <!-- 如果没有该配置,devtools不会生效 -->
                </configuration>
                <executions>
                    <execution>
                        <goals>
                            <goal>repackage</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>

在 Vue 项目的打包过程中,是否将依赖一起打包取决于构建工具的配置和使用方式。默认情况下,Vue 项目使用 Webpack 或 Vite 等工具进行打包,会将项目依赖一同打包进最终的 JavaScript 文件中。 如果使用 Webpack 构建 Vue 项目,并通过 `npm run build` 命令执行打包操作,Webpack 会将所有依赖项(包括本地安装的 `node_modules` 中的依赖)进行静态资源打包,最终输出为一个或多个包含依赖的 JavaScript 文件。这种打包方式使得项目在部署后无需依赖外部网络即可运行,适用于内网开发等无法访问外部资源的场景 [^2]。 在 Vite 构建的 Vue 项目中,打包行为略有不同。Vite 默认使用 ES 模块进行开发,依赖不会立即打包进最终文件,而是通过浏览器原生的模块加载机制进行按需加载。但在执行 `vite build` 命令时,Vite 会通过 Rollup 对项目进行打包,并将依赖项进行优化和合并,最终生成包含依赖的静态资源文件 [^4]。 此外,可以通过配置手动实现依赖分包。例如在 Vite 中使用 `manualChunks` 配置,将 `node_modules` 中的依赖单独打包成一个名为 `vendor` 的 chunk: ```javascript manualChunks(id) { if (id.includes('node_modules')) { return 'vendor'; } } ``` 这种方式可以提升加载性能,同时便于缓存管理 [^4]。 如果项目中使用了 CDN 引入依赖(如 Vue、Vue Router 等),则可以通过 `externals` 配置排除这些依赖的打包,从而减少最终构建产物的体积: ```javascript module.exports = { configureWebpack: { externals: { vue: 'Vue', 'vue-router': 'VueRouter' } } }; ``` 此时依赖将不会被打包进最终的 JavaScript 文件中,而是在运行时通过 CDN 加载 [^3]。 综上所述,Vue 项目打包时是否包含依赖,取决于构建工具的配置。默认情况下依赖会被打包进最终产物中,但也可以通过配置实现依赖分包或排除依赖打包。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值