1 В избранное 0 Ответвления 0

OSCHINA-MIRROR/ha-lang-react-hooks

Присоединиться к Gitlife
Откройте для себя и примите участие в публичных проектах с открытым исходным кодом с участием более 10 миллионов разработчиков. Приватные репозитории также полностью бесплатны :)
Присоединиться бесплатно
Это зеркальный репозиторий, синхронизируется ежедневно с исходного репозитория.
Клонировать/Скачать
webpack.config.js 5.9 КБ
Копировать Редактировать Web IDE Исходные данные Просмотреть построчно История
halang Отправлено 3 лет назад f3c6e4e
const path = require('path')
const HtmlWebpackPlugin = require('html-webpack-plugin'); // 本都服务
const webpack = require('webpack')
const webpackbar = require("webpackbar"); // 美化终端构建时的进度条样式
const MiniCssExtractPlugin = require('mini-css-extract-plugin'); // 样式隔离
// function generateScopedName() {
// const name = process.env.NODE_ENV === 'production' ? '[hash:base64:5]' : '[path][name]__[local]__[hash:base64:5]';
// return name;
// }
module.exports = {
entry: {
main: ['./src/index.tsx']
}, // 指定构建入口文件
output: {
path: path.resolve(__dirname, 'dist'), // 指定构建生成文件所在路径
filename: 'bundle.[name].js', // 指定构建生成的文件名
},
module: {
rules: [
{
test: /\.(tsx|ts)?$/,
exclude: /node_modules/,
loader: 'babel-loader',
options: {
presets: [
'@babel/preset-env',
'@babel/preset-react',
'@babel/preset-typescript'
]
}
},
// {
// // .tsx用typescript-loader解析解析
// test: /\.(ts|tsx|js|jsx)?$/,
// use: [
// {
// loader: "awesome-typescript-loader",
// options: {
// getCustomTransformers: () => ({
// before: [
// tsImportPluginFactory({
// libraryName: "antd",
// libraryDirectory: "lib",
// style: true,
// }),
// ],
// }),
// },
// },
// ],
// include: path.resolve(__dirname, "src"),
// },
// {
// test: /\.js?/,
// include: [
// path.resolve(__dirname, 'src'),
// ],
// use: {
// loader: 'babel-loader', //指定使用loader
// options: {
// presets: [
// [
// '@babel/preset-env',
// {
// // 按需加载
// useBuiltIns: 'usage',
// // 指定core-js版本
// corejs: {
// version: 3
// },
// // 指定兼容性做到哪个版本浏览器
// targets: {
// chrome: '60',
// firefox: '60',
// ie: '8',
// safari: '10',
// edge: '17'
// }
// }
// ]
// ]
// }
// }
// },
// {
// test: /\.js?/,
// include: [
// path.resolve(__dirname, 'src'), // 指定哪些路径下的文件需要经过 loader 处理
// ],
// use: {
// loader: 'babel-loader', // 指定使用的 loader
// options: {
// presets: ['@babel/preset-env'],
// },
// },
// },
{
test: /\.css$/, //.css配置
// include: [
// path.resolve(__dirname, 'src'),
// ],
use: [
MiniCssExtractPlugin.loader,
// 'style-loader',
'css-loader',
'postcss-loader'
]
},
{
test: /\.less$/, //.less配置
include: [
path.resolve(__dirname, 'src'),
],
use: [
MiniCssExtractPlugin.loader,
// 'style-loader',
'css-loader',
'postcss-loader',
'less-loader',
]
},
{
test: /\.(eot|woff|otf|svg|ttf|woff2|appcache|mp3|mp4|pdf)(\?|$)/,
include: path.resolve(__dirname, 'src'),
use: [
{
loader: 'file-loader',
options: {
name: "assets/[name].[hash:4].[ext]"
}
}
]
},
{
test: /\.(png|jpg|jpeg|gif)$/i, // 配置图片
include: [
path.resolve(__dirname, 'src'),
],
use: [
{
loader: "url-loader",
options: {
limit: 8192,
name: "assets/[name].[hash:4].[ext]"
}
}
]
}
]
},
plugins: [
new webpackbar(),
new webpack.DefinePlugin({
PRODUCTION: JSON.stringify(true), // const PRODUCTION = true
VERSION: JSON.stringify('5fa3b9'), // const VERSION = '5fa3b9'
BROWSER_SUPPORTS_HTML5: true, // const BROWSER_SUPPORTS_HTML5 = 'true'
TWO: '1+1', // const TWO = 1 + 1,
CONSTANTS: {
APP_VERSION: JSON.stringify('1.1.2') // const CONSTANTS = { APP_VERSION: '1.1.2' }
}
}),
new HtmlWebpackPlugin({
template: 'src/index.html', // 配置文件模板
inject: true, // JS文件注入到body结尾,CSS文件注入到head中
minify: {
removeComments: true, // 删除模版文件中的注释
}
}),
],
resolve: {
extensions: [".js", ".jsx", ".ts", ".tsx", ".less", ".css", ".wasm"], // 后缀自动补全
alias: {
"@": path.resolve(__dirname, 'src'), // 路径别名
},
// modules: ['node_modules'],
},
// 使用SplitChunksPlugin不需要安装任何依赖,只需在 webpack.config.js 中的 config对象添加 optimization 属性:
// optimization: {
// namedModules: true, //配置hot加载,替代webpack4的 new webpack.NamedModulesPlugin(),
// }
}

Комментарий ( 0 )

Вы можете оставить комментарий после Вход в систему

1
https://gitlife.ru/oschina-mirror/ha-lang-react-hooks.git
git@gitlife.ru:oschina-mirror/ha-lang-react-hooks.git
oschina-mirror
ha-lang-react-hooks
ha-lang-react-hooks
master