Sam*_*uel 4 webpack css-loader webpack-file-loader
我对webpack / npm还是很陌生,我正设法让我了解如何在其他项目相关性中使用CSS url。
资料夹结构
src
fonts/
scss/
app.scss
js/
app.js
img/
index.html
Run Code Online (Sandbox Code Playgroud)
webpack.config.js
var path = require('path');
var extractPlugin = require('extract-text-webpack-plugin');
var cleanWebpackPlugin = require('clean-webpack-plugin');
var htmlWebpackPlugin = require('html-webpack-plugin');
var webpack = require("webpack");
module.exports = {
entry: './src/js/app.js',
output: {
path: path.resolve(__dirname, 'dist'),
filename: 'js/app.js'
},
devServer: {
stats: 'errors-only',
compress: true,
open: true,
port: 9000
},
module: {
rules: [
// ES6 -> ES5 transpiler
{
test: /\.js$/,
exclude: /node_modules/,
use: {
loader: 'babel-loader',
options: {
presets: ['es2015']
}
}
},
// SCSS to CSS -> Autoprefix -> Load CSS
{
test: /\.(scss|css)$/,
use: extractPlugin.extract({
use: [
'css-loader',
{
loader: 'postcss-loader',
options: {
plugins: (loader) => [require('autoprefixer')()]
}
},
'sass-loader'
]
})
},
// HTML Loader
{
test: /\.html$/,
use: ['html-loader']
},
// Image Loader
{
test: /\.(jpg|png|svg|gif)$/,
use: [
{
loader: 'file-loader',
options: {
outputPath: 'img/',
name: '[name].[ext]'
}
}
]
},
// Font Loader
{
test: /\.(eot|ttf|woff)$/,
use: [
{
loader: 'file-loader',
options: {
outputPath: 'fonts/',
name: '[name].[ext]'
}
}
]
}
]
},
plugins: [
new extractPlugin({filename: 'scss/app.css'}),
new cleanWebpackPlugin(['dist']),
new htmlWebpackPlugin({ template: 'src/index.html' }),
new webpack.ProvidePlugin({ $: 'jquery', jQuery: 'jquery', 'window.jQuery': 'jquery' })
]
};
Run Code Online (Sandbox Code Playgroud)
我已经成功地将lightGallery包含在我的项目中,如下所示:
app.js
import 'lightgallery';
Run Code Online (Sandbox Code Playgroud)
app.scss
@import '~lightgallery/dist/css/lightgallery.css';
Run Code Online (Sandbox Code Playgroud)
light gallery样式表引用了我已成功fonts/使用Webpack 加载到的字体file-loader
我的问题是,内置的CSS文件正在尝试从scss文件夹而不是我的根目录引用相对字体。
即: http://localhost:9000/scss/img/loading.gif
我需要从CSS链接到的所有资产才能从我的根目录进行解析
即 http://localhost:9000/img/loading.gif
无论如何,我可以将css-loader配置为在所有url前面添加一个/吗?
救命!
在file-loader尊重output.publicPath,而是因为你还没有设置,则生成的路径将是一个相对路径。您可以将公共路径设置为/。
output: {
path: path.resolve(__dirname, 'dist'),
filename: 'js/app.js',
publicPath: '/'
},
Run Code Online (Sandbox Code Playgroud)
这也会影响处理任何资产的其他加载器和插件。通常这是您想要的,因此建议您这样做,但是,如果您只想更改特定文件,则可以使用上的publicPath选项file-loader。
{
loader: 'file-loader',
options: {
outputPath: 'img/',
name: '[name].[ext]',
publicPath: '/'
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6770 次 |
| 最近记录: |