我从 Vue.js 和 Webpack 开始,对如何正确导入和引用我的字体、CSS 和node_modules
正确。
我开始使用我的应用程序vue-cli
,这是最终的结构:
build
config
node_modules
src
--assets
--components
--router
static
这是我的webpack.base.conf
file:
var path = require('path')
var utils = require('./utils')
var config = require('../config')
var vueLoaderConfig = require('./vue-loader.conf')
function resolve (dir) {
return path.join(__dirname, '..', dir)
}
module.exports = {
entry: {
app: './src/main.js'
},
output: {
path: config.build.assetsRoot,
filename: '[name].js',
publicPath: process.env.NODE_ENV === 'production'
? config.build.assetsPublicPath
: config.dev.assetsPublicPath
},
resolve: {
extensions: ['.js', '.vue', '.json'],
alias: {
'vue$': 'vue/dist/vue.esm.js',
'@': resolve('src')
}
},
module: {
rules: [
{
test: /\.(js|vue)$/,
loader: 'eslint-loader',
enforce: 'pre',
include: [resolve('src'), resolve('test')],
options: {
formatter: require('eslint-friendly-formatter')
}
},
{
test: /\.vue$/,
loader: 'vue-loader',
options: vueLoaderConfig
},
{
test: /\.js$/,
loader: 'babel-loader',
include: [resolve('src'), resolve('test')]
},
{
test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
loader: 'url-loader',
options: {
limit: 10000,
name: utils.assetsPath('img/[name].[hash:7].[ext]')
}
},
{
test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
loader: 'url-loader',
options: {
limit: 10000,
name: utils.assetsPath('fonts/[name].[hash:7].[ext]')
}
}
]
}
}
首先,放置自定义 CSS 和图像的正确位置在哪里?我目前正在把它们放进去assets/css
and assets/img
,分别(我创建了这些文件夹)。这是对的吗?
我还通过 NPM 安装了来自外部库(例如 Bootstrap 和 Font Awesome)的一些 CSS 和字体。他们位于node_modules
.
如果我没记错的话,Webpack 会进行转换,并将这些文件复制到另一个位置。如何在我的 Vue 文件和 CSS 文件中引用它们?
Using import './assets/css/style.css'import '../node_modules/path/to/bootstrap.min.css'
有效(至少在生产中),但我应该使用另一条路径吗?
在我的自定义 CSS 文件中,我使用以下方法引用了外部库中的一些字体:
src: url('/node_modules/roboto-fontface/fonts/Roboto/Roboto-LightItalic.eot')
代码可以编译,但是当我在浏览器中打开页面时,在搜索这些字体时收到 404 错误。我应该如何在自定义 CSS 中引用这些字体?