在 cli 中一定需要传 path 参数的
Param webpack is
webpack chain
, Webpack Chain Github
apiUrl: '//example.com', // api 的地址
baseUrl: './', // 项目的根路径,默认是 __dirname
bundleAnalyzer: true, // 打包文件的分析
execute: './index.js', // 执行文件路径
favicon: './public/icon-coin.png', // favicon 路径
gzip: true, // 开启 gzip
port: 3000, // 热开发端口
htmlName: 'index', // html 的名字
htmlTitle: 'ex', // html 标题
name: 'example', // 项目名字,打包的文件名
outDir: './dist', // 输出的项目路径
proxy: {
'/api/**': {
target: 'https://www.api.com',
secure: false,
changeOrigin: true
}
},
staticDir: 'static', // 静态文件打包路径
tpl: true, // 使用项目自带的 html 模板,默认为 false
type: 'spa', // 项目类型 spa | map
httpsOpt: true | { httpcert: './example.com.cert' }, // webpack 的 https 的配置
webpack(config) {
// webpack chain config
// see https://github.com/neutrinojs/webpack-chain for config.
// 需要返回 config
return config
}
require 引入时可以只传入 config
参数,则必须传入 path
。
如果也传入 configPath
了,会和 config
合并,且 config
的优先级更高
const vue2doBuild = require('@vue2do/build')
vue2doBuild.dev({
config: {
httpsOpt: false
},
configPath: path.resolve(__dirname, '../project.config.js')
})
vue2doBuild.prod({
config: {
httpsOpt: false,
path: __dirname
}
})
'jsx|tsx|pre': {
...commonRule,
test: /\.(j|t)sx?$/,
enforce: 'pre',
use: {
eslint: {
loader: 'eslint-loader'
}
}
},
'ts|tsx': {
...commonRule,
test: /\.tsx?$/,
use: {
babel: babelLoader,
ts: {
loader: 'ts-loader',
options: {
transpileOnly: true,
experimentalWatchApi: true,
compilerOptions: {
module: 'es6',
noEmit: true
}
}
}
}
},
'js|jsx': {
...commonRule,
test: /\.jsx?$/,
use: {
babel: babelLoader
}
},
css: {
...commonRule,
include: [
...commonRule.include
],
test: /\.(css)$/,
use: {
style: {
loader: extractScss ? MiniCssExtractPlugin.loader : 'style-loader'
},
css: {
loader: 'css-loader'
},
postcss: {
loader: 'postcss-loader'
}
}
},
scss: {
...commonRule,
test: /\.(scss)$/,
use: {
style: {
loader: extractScss ? MiniCssExtractPlugin.loader : 'style-loader'
},
css: {
loader: 'css-loader'
},
postcss: {
loader: 'postcss-loader'
},
sass: {
loader: 'sass-loader'
}
}
},
less: {
...commonRule,
test: /\.(less)$/,
use: {
style: {
loader: extractScss ? MiniCssExtractPlugin.loader : 'style-loader'
},
css: {
loader: 'css-loader'
},
postcss: {
loader: 'postcss-loader'
},
sass: {
loader: 'less-loader'
}
}
},
img: {
...commonRule,
test: /\.(png|jpe?g|gif|svg|woff2?|eot|ttf|otf)(\?.*)?$/,
use: {
url: {
loader: 'url-loader',
options: {
limit: 10000,
name: utils.assetsPath('fonts/[name].[hash:7].[ext]')
}
}
}
},
media: {
...commonRule,
test: /\.(mp3|aac|ogg)(\?.*)?$/,
use: {
file: {
loader: 'file-loader'
}
}
},
'html|tpl': {
...commonRule,
test: /\.(html|tpl)$/,
use: {
file: {
loader: 'html-loader'
}
}
}
// base
...
plugin: {
forkTsChecker: {
plugin: ForkTsCheckerWebpackPlugin,
args: [{
eslint: true,
async: true,
watch: [projectPath],
reportFiles: [projectPath]
}]
}
},
...
// dev
...
plugin: {
dashboard: {
plugin: DashboardPlugin
},
webpackLoaderOptions: {
plugin: webpack.LoaderOptionsPlugin,
args: [{
debug: true
}]
},
webpackHotModuleReplacement: {
plugin: webpack.HotModuleReplacementPlugin
},
webpackNamedModules: {
plugin: webpack.NamedModulesPlugin
},
webpackNoEmitOnErrors: {
plugin: webpack.NoEmitOnErrorsPlugin
},
webpackOptimizeOccurrenceOrder: {
plugin: webpack.optimize.OccurrenceOrderPlugin
},
progressBar: {
plugin: ProgressBarPlugin,
args: [{
format: `build [:bar] ${chalk.green.bold(':percent')} (:elapsed 秒)`,
complete: '>',
incomplete: '-',
clear: false
}]
},
html: {
plugin: HtmlWebpackPlugin,
args: [{
filename: `${projectConfig.htmlName ? projectConfig.htmlName : 'index'}.html`,
template,
title: projectConfig.htmlTitle,
inject: true,
favicon: projectConfig.favicon && path.resolve(projectConfig.path, projectConfig.favicon)
}]
}
},
...
// prod
...
plugin: {
clean: {
plugin: CleanWebpackPlugin,
args: [{
// dry: true,
verbose: true
}]
},
uglifyJs: {
plugin: UglifyJsPlugin,
args: [{
uglifyOptions: {
compress: true,
cache: true,
ie8: false,
parallel: true,
output: {
comments: false,
beautify: false
},
sourceMap: config.prod.sourceMap,
warnings: false
}
}]
},
html: {
plugin: HtmlWebpackPlugin,
args: [{
filename: `${projectConfig.htmlName ? projectConfig.htmlName : 'index'}.html`,
template,
title: projectConfig.htmlTitle,
inject: true
}]
}
}
...
vue2do-build dev projectPath/project.config.js
vue2do-build prod projectPath/project.config.js
const vue2doBuild = require('@vue2do/build')
vue2doBuild.dev({
config: {
httpsOpt: false
},
configPath: path.resolve(__dirname, '../project.config.js')
})
vue2doBuild.prod({
config: {
httpsOpt: false
},
configPath: path.resolve(__dirname, '../project.config.js')
})
return: base | dev | prod
const configuration = getConfig({
config: {
path: path.dirname(projectConfigPath)
}
})