mpvue-simple
Version:
辅助 mpvue 快速开发 Page / Component 级小程序页面的工具
94 lines (88 loc) • 2.21 kB
JavaScript
var path = require('path')
var fs = require('fs')
var utils = require('./utils')
var config = require('../config')
var vueLoaderConfig = require('./vue-loader.conf')
function resolve (dir) {
return path.resolve(dir)
}
const entry = process.env.NODE_ENV === 'production'
? config.build.entry
: config.dev.entry
const modules = [path.join(__dirname, '../'), path.join(__dirname, '../node_modules'), resolve('./'), resolve('./node_modules')]
// mp compiler 全局模式下注入 babelrc
vueLoaderConfig.globalBabelrc = path.resolve(__dirname, '../.babelrc')
module.exports = {
entry,
target: require('mpvue-webpack-target'),
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': 'mpvue',
'@': resolve('src')
},
symlinks: false,
modules
},
resolveLoader: {
modules
},
module: {
rules: [
{
test: /\.vue$/,
loader: 'mpvue-loader',
options: vueLoaderConfig
},
{
test: /\.js$/,
exclude: /node_modules\/(?!mpvue-simple\/src\/)/,
use: [
{
loader: 'babel-loader',
options: {
extends: vueLoaderConfig.globalBabelrc
}
},
{
loader: 'mpvue-loader',
options: {
checkMPEntry: true
}
},
]
},
{
test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
loader: 'url-loader',
options: {
limit: 10000,
name: utils.assetsPath('img/[name].[ext]')
}
},
{
test: /\.(mp4|webm|ogg|mp3|wav|flac|aac)(\?.*)?$/,
loader: 'url-loader',
options: {
limit: 10000,
name: utils.assetsPath('media/[name]].[ext]')
}
},
{
test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
loader: 'url-loader',
options: {
limit: 10000,
name: utils.assetsPath('fonts/[name].[ext]')
}
}
]
}
}