Output

output配置如何输出最终想要的代码,output是一个object里面包含一系列配置。

1. filename

output.filename配置输出文件的名称,为string类型,如果只有一个输出文件,我们可以将它写为静态不变的:

filename: 'bundel.js'

现在有多个chunk要输出时,就需要借助模板和变量了,前面说到webpack会为每个chunk取一个名称,通过占位符确保文件名称的唯一性,可以根据chunk名称来区分输出的文件名:

filename: '[name].js'

代码里的[name]代表用内置的name变量去替换[name],这时你可以把它看做一个字符串模板函数,每个要输出的chunk都会通过这个函数去拼接出输出的文件名称。

内置变量还有如下:

1. id, chunk的唯一标识,从0开始。
2. name, chunk的名称。
3. hash, chunk的唯一标识的hash值。
4. chunkhash, chunk内容的hash值。 其中hash和chunkhash的长度可以指定的,[hash:8]这样去指定,默认是20位。
2. chunkFilename

output.chunkFilename, 配置无入口的chunk在输出时的文件名称。chunkFilename和filename非常类似,但是chunkFilename只用于指定在运行过程中生成的chunk在输出的时的文件名称。常见的会在运行时生成chunk场景只有在使用CommonChunkPlugin,使用import('path/to/module')动态加载等时,chunkFilename支持和filename一致的内置变量。

3. path

output.path配置输出文件存放在本地的目录,必须是string类型的绝对路径

path: path.resolve(__dirname, 'dist_[hash]')
4. publicPath

在项目中可能会有一些构建出的资源需要异步加载,加载这些异步资源需要对应的URL地址。
output.publicPath配置发布到线上资源的URL前缀,为string类型,默认值是空字符串,即使用相对路径。
output.path和output.publicPath都支持字符串模板,内置变量只有一个:hash代表编译一次的hash值。

5. crossOrginLoading

webpack输出的部门代码可能需要异步加载,而异步加载时通过jsonp方式实现。jsonp的原理是动态的向HTML中插入一个script标签去异步加载资源。

output.crossOriginLoading则是用于配置这个异步插入标签的crossorigin值。

script标签的crossorigin属性可以取以下值:

1. anonymous(默认)在加载此脚本资源时不会带上用户的cookie;
2. use-credentials 在加载此脚本资源时会带上用户的cookies;

通常设置crossorigin来获取异步加载的脚本执行时的详细错误信息。

6. libraryTarge和library

当webpack去构建一个可以被其他模块导入使用的库时需要用到他们。

1. output.libraryTarget 配置以何种方式导出库。
2. output.library 配置导出库的名称。

它们通常搭配在一起使用。

output.libraryTarget是字符串的枚举类型,支持以下配置:

    1. var(默认)

编写的库将通过var被赋值给通过library指定名称的变量。
假如配置了output.library='LibraryName', 则输出和使用的代码如下:

//webpack输出代码
var LibraryName = lib_code //使用库的方法
LibraryName.doSomething()

假如output.library为空,则将直接输出:

lib_code //lib_code代指导出库的代码内容,是有返回值的一个自执行函数。
    1. commonjs

编写库将通过commonjs规范导出。
假如配置了output.library='LibraryName', 则输出和使用代码如下:

//webpack输出的代码
exports['LibraryName'] = lib_code //使用库的方法
require('library-name-in-npm')['libraryName'].doSomething()
    1. commonjs2

编写的库将通过 commonjs2规范导出,输出和使用代码如下:

//webpack输出的代码
module.exports = lib_code //使用库的方法
require('library-name-in-npm').doSomething()
    1. this

编写的库将通过this被赋值给通过library指定的名称:

//webpack 输出的代码
this['LibraryName'] = lib_code //使用库的方法
this.libraryName.doSomething()
    1. window

编写的库将通过window被赋值给library指定的名称

//webpack输出的代码
window['LibraryName'] = lib_code //使用库的方法
window.libraryName.doSomething()
    1. global

编写的库将通过global被赋值给通过library指定的名称

//webpack输出的代码
global['LibraryName'] = lib_code //使用库的方法
global.libraryName.doSomething()
6. libraryExport

output.libraryExport配置要导出的模块中哪些子模块需要被导出,它只有在output.libraryTarget被设置为commonjs或者commonjs2时使用才有意义。
假如要导出的模块源码是:

export const a = 1
export default b = 2

现在你想让构建输出的代码只导出其中的a, 可以把output.libraryExport设置成a, 那么构建输出的代码和使用方法将变成如下:

 
module.exports = lib_code['a']

require('library-name-in-npm') === 1

webpack(3)--Output的更多相关文章

  1. webpack中output配置项中chunkFilename属性的用法

    chunkFilename和webpack.optimize.CommonsChunkPlugin插件的作用差不多,都是用来将公共模块提取出来,但是用法不一样,这里主要介绍chunkFilename的 ...

  2. Webpack中hash与chunkhash的区别,以及js与css的hash指纹解耦方案

    文件的hash指纹通常作为前端静态资源实现增量更新的方案之一,Webpack是目前最流行的开源编译工具之一,其强大的功能也带来很多坑(当然,大部分麻烦其实都可以在官方文档中找到答案). 比如,在Web ...

  3. 利用免费cdn加速webpack单页应用

    回顾现状 在之前的学习过程中,react单页应用经过webpack打包之后会输出大概如下的目录结构,它就是站点的所有前端组成了:   1 2 3 4 5 6 MacBook-Pro:output ba ...

  4. webpack的安装和使用

    Webpack是什么 首先可以看下 官方文档 ,文档是最好的老师. Webpack是由Tobias Koppers开发的一个开源前端模块构建工具.它的基本功能是将以模块格式书写的多个JavaScrip ...

  5. webpack入门和实战(二):全面理解和运用loader和plugins

    您的阅读目录: 一.理解webpack加载器loader 二.理解less-loader加载器的使用 三.理解babel-loader加载器的使用 四.webpack命令行常见使用的操作 五.用web ...

  6. webpack 教程 那些事儿03-webpack两大精华插件,热加载

    本节主要讲述 webpack的两大经典开发调试插件,热插拔内存缓存机制 文章目录 1. html-webpack-plugin插件的使用 2. webpack-dev-middleware 插件登场 ...

  7. webpack基础+webpack配置文件常用配置项介绍+webpack-dev-server

    一.webpack基础 1.在项目中生成package.json:在项目根目录中输入npm init,根据提示输入相应信息.(也可以不生成package.json文件,但是package.json是很 ...

  8. webpack入门级教程

    Webpack是什么 首先可以看下官方文档,文档是最好的老师. 这里也有国外的一个朋友写的入门介绍. Webpack是由Tobias Koppers开发的一个开源前端模块构建工具.它的基本功能是将以模 ...

  9. webpack使用

    Webpack是一个现代js应用的模块打包机.如果一个文件依赖另一个文件,webpack认为这就存在一个依赖关系.不管另一个文件是什么内容,image,css或js都被当作一个模块.Webpack从e ...

随机推荐

  1. 强化学习 CartPole实验的一些启发 有没有可能设计一个新的实验呢?(杆子可以向360度方向倾倒,可行吗?)

    最近在看强化学习方面的东西,突然想到了这么一个事情,那就是经典的CartPole游戏我们改变一下,或者说升级一下,那么使用强化学习是否能得到不错的效果呢? 原始游戏如图: 一点个人的想法: ===== ...

  2. OpenCV代码提取:遍历指定目录下指定文件的实现

    前言 OpenCV 3.1之前的版本,在contrib目录下有提供遍历文件的函数,用起来比较方便.但是在最新的OpenCV 3.1版本给去除掉了.为了以后使用方便,这里将OpenCV 2.4.9中相关 ...

  3. EasyTouch基本用法

    EasyTouch基本用法 本文提供全流程,中文翻译.Chinar坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) 1 hierarchy (层次面 ...

  4. (dfs痕迹清理兄弟篇)bfs作用效果的后效性

    dfs通过递归将每种情景分割在不同的时空,但需要对每种情况对后续时空造成的痕迹进行清理(这是对全局变量而言的,对形式变量不需要清理(因为已经被分割在不同时空)) bfs由于不是利用递归则不能分割不同的 ...

  5. 【MVC】知识笔记

    MVC代表:模型-视图-控制器. Models:标识该应用程序的数据并使用验证逻辑来强制实施业务规则的数据类 Views  :应用程序动态生成HTML所使用的模版文件 Controllers:处理浏览 ...

  6. .hex文件和.bin文件的区别

    博客转之于:  http://mini.eastday.com/a/160627003502858.html HEX文件和BIN文件是我们经常碰到的2种文件格式.下面简单介绍一下这2种文件格式的区别: ...

  7. 使用webpack搭建vue项目中遇到的问题

    1:data数据文件经试验,需要放在生成的build文件夹中才能生效,但是应该把data文件夹先放在src中,然后如何定义config文件,让其复制过去? new CopyWebpackPlugin( ...

  8. yugabyte 集成JanusGraph测试

    yugabyte 集成图数据库JanusGraph,原理比较简单就是yugabyte 内置Cassandra,配置好JanusGraph 的访问就可以了. 使用docker 模式部署 创建yugaby ...

  9. 无法对 数据库'XXXXX' 执行 删除,因为它正用于复制

    无法对 数据库'XXXXX' 执行 删除,因为它正用于复制. (.Net SqlClient Data Provider) 使用以下方式一般可以解决 sp_removedbreplication 'X ...

  10. BMP、GIF、JPEG、PNG以及其它图片格式简单介绍

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/songjinshi/article/details/37516649 BMP格式 BMP是英文Bit ...