-
Notifications
You must be signed in to change notification settings - Fork 117
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
【翻译】Webpack——令人困惑的地方 #13
Comments
entry 也支持带目录结构的输出: entry {
'a/b/c': 'c'
} |
对的 支持 但整体来看它还是个map |
webpack感觉就是个复杂的半成品,第三方依赖没有很好的处理方式~ |
很多我啃了很久才理解的东西,这里说清楚了,老外这文章很及时 |
我在配置webpack的时候碰到一些module用babel6转换的情况,但是用require的时候必须要加default。用了add-module-exports这个babel插件但是不会处理node_module里的情况。所以把exclude:/node_module/给去掉了,但是这样导致处理所有的module,速度很慢,又加了include指定node_module下的目录但是不起作用。是不是这两个配置会冲突,exclude里的存在的,include的就不起作用。 preLoaders = [
{
test: /redux-thunk/,
loader: 'babel',
query: webpackConfig.babel
}
] 对于请求路径包含自己想要的模块就先处理一下。这样可以解决自己的需求了,但是不知道是不是很笨,发个issue求正解。 |
@iwx 其实不是很懂你的问题哎 |
@chemdemo https://www.npmjs.com/package/babel-plugin-add-module-exports |
这是babel转换es6的问题吧,跟webpack没啥关系。 不想加default的话可以用花括号: // foo.js
export default foo import { foo } from 'foo' |
我引用了第三方module,module是已经编译好的了,总不能去npm install后修改module吧。 |
mark 顶你 |
疑惑好像慢慢解开了 ,好棒! |
很棒,强烈支持,希望有后面的译文 |
很多之前没明白的地方,都豁然开朗了,好文。赞!! |
好棒 |
我遇到一个问题,就是我在用命令行启动的时候,把 inline 和 hot 都加上了,然后 WDS 就一直用热替换却不刷新,也就是说它一直热替换成功,所以没有刷新过页面,但是我改变一些函数内容,页面执行以后显示的效果却是之前的,也就是说它并没有把这部分函数代码也正确地替换掉,我觉得这种情况下应该认为热替换失败了,然后重新刷新页面才能满足要求。不知道这类问题应该怎样解决?这个问题自己已经解决了,是我自己配置的热更新模块有问题,现在已经能够正确地替换页面元素、样式和函数内容了。 |
webpack2 出来之后不少东西都变了 简直坑爹 |
@hkjpotato Webpack3要出来了 :P |
@Kannnnng 我遇到跟你一样的问题,请问你是怎么解决的? |
@zicongxie 过去的时间有点长了,我现在也不能清晰地记得当时做了哪些具体的改动。不过我可以说一下项目最后的配置。 |
你好,你的webpack配置文件是否方便给我参考一下?
在 2017-08-02 23:26:41,"闫守康" <[email protected]> 写道:
@zicongxie 过去的时间有点长了,我现在也不能清晰地记得当时做了哪些具体的改动。不过我可以说一下项目最后的配置。
一个是在入口文件的 index.js 文件前面添加了 'react-hot-loader/patch' 这一项(我使用的是 "react-hot-loader": "^3.0.0-beta.7")。
另一个是在项目启动的时候, npm start 执行的命令是 webpack-dev-server --hot --progress,其中 --progress 对热更新和热替换没有帮助,只是打印文件的打包过程, --hot 参数是重要的。
我现在的项目就是上面这两个配置,目前能够正常实现热更新和热替换,你如果还没解决问题的话,可以安装我这个配置尝试一下。
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub, or mute the thread.
|
webpack在二级页面自动刷新时页面显示 Cannot Get 这是咋回事,是缺少了什么配置吗? //实现无刷新的替换 app.listen('8080', function(err) { }) |
@ClimbYU 请问你的问题解决了吗?我也是在二级页面刷新出错 |
@basebase ,在路由配置中加入下history属性就可以了, |
@ClimbYU 谢谢老哥 |
great |
great |
mark 写的详细明了 |
原文 Webpack—The Confusing Parts
Webpack是目前基于React和Redux开发的应用的主要打包工具。我想使用Angular 2或其他框架开发的应用也有很多在使用Webpack。
当我第一次看到Webpack的配置文件时,它看起来非常的陌生,我非常的疑惑。经过一段时间的尝试之后我认为这是因为Webpack只是使用了比较特别的语法和引入了新的原理,因此会让使用者感到疑惑。这些也是导致Webpack不被人熟悉的原因。
因为刚开始使用Webpack很让人疑惑,我觉得有必要写几篇介绍Webpack的功能和特性的文章以帮助初学者快速理解。此文是最开始的一篇。
Webpack的核心原理
Webpack的两个最核心的原理分别是:
正如js文件可以是一个“模块(module)”一样,其他的(如css、image或html)文件也可视作模 块。因此,你可以
require('myJSfile.js')
亦可以require('myCSSfile.css')
。这意味着我们可以将事物(业务)分割成更小的易于管理的片段,从而达到重复利用等的目的。传统的模块打包工具(module bundlers)最终将所有的模块编译生成一个庞大的
bundle.js
文件。但是在真实的app里边,“bundle.js”文件可能有10M到15M之大可能会导致应用一直处于加载中状态。因此Webpack使用许多特性来分割代码然后生成多个“bundle”文件,而且异步加载部分代码以实现按需加载。好了,下面来看看那些令人困惑的部分吧。
1. 开发模式和生产模式
首先要知道的是Webpack有许许多多的特性,一些是”开发模式“下才有的,一些是”生产模式“下才有的,还有一些是两种模式下都有的。
为了生成bundles文件你可能在
package.json
文件加入如下的scripts项:2. webpack CLI 和webpack-dev-server
值得注意的是,Webpack作为模块打包工具,提供两种用户交互接口:
Webpack CLI(有利于生产模式下打包)
这种方式可以从命令行获取参数也可以从配置文件(默认叫webpack.config.js)获取,将获取到的参数传入Webpack来打包。
用法:
webpack-dev-server(有利于在开发模式下编译)
这是一个基于Express.js框架开发的web server,默认监听8080端口。server内部调用Webpack,这样做的好处是提供了额外的功能如热更新“Live Reload”以及热替换“Hot Module Replacement”(即HMR)。
用法:
Webpack VS Webpack-dev-server选项
注意像
inline
和hot
这些选项是Webpack-dev-server特有的,而另外的如hide-modules
则是CLI模式特有的选项。webpack-dev-server CLI选项和配置项
另外值得注意的是你可以通过以下两种方式向webpack-dev-server传入参数:
webpack-dev-server的“hot” 和 “inline”选项
“inline”选项会为入口页面添加“热加载”功能,“hot”选项则开启“热替换(Hot Module Reloading)”,即尝试重新加载组件改变的部分(而不是重新加载整个页面)。如果两个参数都传入,当资源改变时,webpack-dev-server将会先尝试HRM(即热替换),如果失败则重新加载整个入口页面。
3. “entry”:值分别是字符串、数组和对象的情况
Enter配置项告诉Webpack应用的根模块或起始点在哪里,它的值可以是字符串、数组或对象。这看起来可能令人困惑,因为不同类型的值有着不同的目的。
像绝大多数app一样,倘若你的应用只有一个单一的入口,enter项的值你可以使用任意类型,最终输出的结果都是一样的。
enter:数组类型
但是,如果你想添加多个彼此不互相依赖的文件,你可以使用数组格式的值。
例如,你可能在html文件里引用了“googleAnalytics.js”文件,可以告诉Webpack将其加到bundle.js的最后。
enter:对象
现在,假设你的应用是多页面的(multi-page application)而不是SPA,有多个html文件(index.html和profile.html)。然后你通过一个对象告诉Webpack为每一个html生成一个bundle文件。
以下的配置将会生成两个js文件:indexEntry.js和profileEntry.js分别会在index.html和profile.html中被引用。
用法:
注意:文件名取自“entry”对象的键名。
enter:混合类型
你也可以在enter对象里使用数组类型,例如下面的配置将会生成3个文件:vender.js(包含三个文件),index.js和profile.js文件。
4. output:“path”项和“publicPath”项
output项告诉webpack怎样存储输出结果以及存储到哪里。output的两个配置项“path”和“publicPath”可能会造成困惑。
“path”仅仅告诉Webpack结果存储在哪里,然而“publicPath”项则被许多Webpack的插件用于在生产模式下更新内嵌到css、html文件里的url值。
例如,在localhost(译者注:即本地开发模式)里的css文件中边你可能用“./test.png”这样的url来加载图片,但是在生产模式下“test.png”文件可能会定位到CDN上并且你的Node.js服务器可能是运行在HeroKu上边的。这就意味着在生产环境你必须手动更新所有文件里的url为CDN的路径。
然而你也可以使用Webpack的“publicPath”选项和一些插件来在生产模式下编译输出文件时自动更新这些url。
5. 模块加载和链式模块加载
模块加载器是可自由添加的Node模块,用于将不同类型的文件“load”或“import”并转换成浏览器可以识别的类型,如js、Stylesheet等。更高级的模块加载器甚至可以支持使用ES6里边的“require”或“import”引入模块。
例如,你可以使用
babel-loader
来将使用ES6语法写成的文件转换成ES5:链式(管道式)的加载器(从右往左执行)
多个loader可以用在同一个文件上并且被链式调用。链式调用时从右到左执行且loader之间用“!”来分割。
例如,假设我们有一个名为“myCssFile.css”的css文件,然后我们想将它的内容使用style标签内联到最终输出的html里边。我们可以使用css-loader和style-loader两个loader来达到目的。
这里展示它是如何工作的:
6. loader自身可以配置
模块加载器(loader)自身可以根据传入不同的参数进行配置。
在下面的例子中,我们可以配置url-loader来将小于1024字节的图片使用DataUrl替换而大于1024字节的图片使用url,我们可以用如下两种方式通过传入“limit“参数来实现这一目的:
7. .babelrc 文件
babal-loader使用”presets“配置项来标识如何将ES6语法转成ES5以及如何转换React的JSX成js文件。我们可以用如下的方式使用”query“参数传入配置:
然而在很多项目里babel的配置可能比较大,因此你可以把babel-loader的配置项单独保存在一个名为”.babelrc“的文件中,在执行时babel-loader将会自动加载.babelrc文件。
所以在很多例子里,你可能会看到:
8. 插件
插件一般都是用于输出bundle的node模块。
例如,uglifyJSPlugin获取bundle.js然后压缩和混淆内容以减小文件体积。
类似的extract-text-webpack-plugin内部使用css-loader和style-loader来收集所有的css到一个地方最终将结果提取结果到一个独立的”styles.css“文件,并且在html里边引用style.css文件。
注意:如果你只是想把css使用style标签内联到html里,你不必使用extract-text-webpack-plugin,仅仅使用css loader和style loader即可:
9. 加载器(loader)和插件
你可能已经意识到了,Loader处理单独的文件级别并且通常作用于包生成之前或生成的过程中。
而插件则是处理包(bundle)或者chunk级别,且通常是bundle生成的最后阶段。一些插件如commonschunkplugin甚至更直接修改bundle的生成方式。
10. 处理文件的扩展名
很多Webpack的配置文件都有一个
resolve
属性,然后就像下面代码所示有一个空字符串的值。空字符串在此是为了resolve一些在import文件时不带文件扩展名的表达式,如require('./myJSFile')
或者import myJSFile from './myJSFile'
(译者注:实际就是自动添加后缀,默认是当成js文件来查找路径)就这么多。
The text was updated successfully, but these errors were encountered: