我已经苦思冥想了一段时间,不知道是否有可能开始。感谢对此的任何帮助!
npm包
我有一个 npm 包,基本上是一个 React 组件库。这个库内置了样式表,其中引用了来自 CSS 的字体和图像等资源。然后使用 webpack 将它们全部打包成 my-package.js
。
配置如下:
var path = require('path');
module.exports = {
module: {
loaders: [
{
test: /\.js$/,
loaders: ['babel-loader'],
exclude: /node_modules/
},
{
test: /\.css$/,
loader: "style-loader!css-loader"
},
{
test: /\.(png|jpg|jpeg|gif|svg|woff|woff2|ttf|eot)$/,
loader: 'file-loader'
},
{
test: /\.styl$/,
loader: 'style-loader!css-loader!stylus-loader'
}
]
},
entry: [
'./lib/components/index.js',
'./lib/index.styl'
],
output: {
path: path.join(__dirname, 'build/'),
filename: 'my-package.js'
}
}
使用./lib/components/index.js
,看起来像:
import '../index.styl';
import MyComponent from './my-component.js';
export {
MyComponent
}
到目前为止,一切都很顺利。
应用程序
现在,在另一个代码库中,我有主要的应用程序,它安装了这个npm包。
我的应用程序根目录需要这个包...
import MyPackage from 'my-package';
然后将其自身webpack捆绑并加载到浏览器中。所有的脚本和样式块都被正确地捆绑,但是引用资产的样式使用了npm包自身的相对网址,因此应用程序会出现404错误。
有没有办法告诉webpack从node_modules/my-package/build/[webpack-generated-name].jpg
解析这些图像?
我的应用程序的webpack配置如下:
var path = require('path'),
webpack = require('webpack');
module.exports = {
devtool: '#eval-source-map',
entry: [
'my-package',
'webpack/hot/only-dev-server',
'./app/index.js',
],
output: {
path: path.join(__dirname, 'build/static'),
filename: 'bundled.js',
publicPath: '/',
},
plugins: [
new webpack.HotModuleReplacementPlugin()
],
resolve: {
extensions: ['', '.js']
},
resolveLoader: {
'fallback': path.join(__dirname, 'node_modules')
},
module: {
loaders: [
{
test: /\.js$/,
loaders: ['react-hot', 'babel'],
exclude: /node_modules/,
include: __dirname
},
{
test: /\.css?$/,
loader: "style-loader!css-loader",
include: __dirname
},
{
test: /\.(jpg|jpeg|ttf|eot|svg|woff(2)?)(\?[a-z0-9]+)?$/,
loader: 'file-loader'
},
{
test: /\.styl$/,
loader: 'style-loader!css-loader!stylus-loader'
}
]
}
};