02 - webpack: output
/** output告知 webpack 如何向硬盘写入编译文件,最少有一个 filenname 属性,告知webpack输出文件的名称,且只能有一个 output 配置 1.output 常用对象属性: filename: 输出文件的名称,可以使用占位符来确保每个文件的名称唯一 path: 输出文件的位置(路径),output.path 中的 URL 以 HTML 页面为基准 publicPath: 引用资源(静态资源:图片、视频、文件、本地js库,或者远程资源:远程库、CDN)相对于HTML页面的路径 服务器也会默认从 publicPath 为基准,使用它来决定在哪个目录下启用服务,来访问 webpack 输出的文件 output: { // One of the below publicPath: 'auto', // 从`import.meta.url`, `document.currentScript`, `<script />` 或者 `self.location` 中的路径自动识别 publicPath: 'https://cdn.example.com/assets/', // CDN(总是 HTTPS 协议) publicPath: '//cdn.example.com/assets/', // CDN(协议相同) publicPath: '/assets/', // 相对于服务(server-relative) publicPath: 'assets/', // 相对于 HTML 页面 publicPath: '../assets/', // 相对于 HTML 页面 publicPath: '', // 相对于 HTML 页面(目录相同) } 2.常用案例: 1.多入口起点使用占位符 module.export = { entry: { app: './src/app.js', search: './src/search.js', }, output: { filename: '[name].js', path: __dirname + '/dist', } } 2.使用CDN和hash output: { path: '/home/proj/cdn/assets/[fullhash]', publicPath: 'https://cdn.example.com/assets/[fullhash]/', } 3.要点: 不知道最终输出文件的 publicPath 是什么地址,则可以将其留空,并且在运行时通过入口起点文件中的 __webpack_public_path__ 动态设置。 __webpack_public_path__ = myRuntimePublicPath; **/ // 实例: module.export = { output: { filename: 'bundle.js', } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)