只是需要一些帮助,请我在这场斗争中失去理智。我已经搜索了很多此类相同问题的帖子,但没有成功,这就是我在这里寻求帮助的原因。
我目前在 webpack-dev-server 上运行简单的 React,当我想建立 preact compat 时,我得到了这个错误:
您可能需要适当的加载器来处理 Client.jsx 上的这种文件类型
这是文件:
客户端.jsx
import React from 'react';
import { render } from 'react-dom';
import { BrowserRouter } from 'react-router-dom';
import App from './App';
const renderClient = () => {
render(
<BrowserRouter>
<App />
</BrowserRouter>,
document.getElementById('app'),
);
};
renderClient();
webpack.config.js
const path = require('path');
const webpack = require('webpack');
const config = {
context: __dirname,
entry: './src/components/Client.jsx',
devtool: 'cheap-module-eval-source-map',
output: {
path: path.join(__dirname, 'public'),
filename: 'bundle.js',
publicPath: '/public/',
},
resolve: {
extensions: ['.js', '.jsx', '.json'],
alias: {
react: 'preact-compat',
'react-dom': 'preact-compat',
},
},
devServer: {
publicPath: '/public/',
historyApiFallback: true,
},
stats: {
colors: true,
reasons: true,
chunks: false,
},
plugins: [new webpack.NamedModulesPlugin()],
module: {
rules: [
{
enforce: 'pre',
test: /\.js$/,
loader: 'eslint-loader',
exclude: /node_modules/,
},
{
test: /\.jsx?$/,
loader: 'babel-loader',
include: [path.resolve('js'), path.resolve('node_modules/preact-compat/src')],
},
],
},
};
if (process.env.NODE_ENV === 'production') {
config.devtool = 'source-map';
config.plugins = [];
}
module.exports = config;
.babelrc
{
"plugins": [
["transform-react-jsx", { "pragma": "h" }],
[
"module-resolver",
{
"root": ["."],
"alias": {
"react": "preact-compat",
"react-dom": "preact-compat"
}
}
]
],
"presets": [
"react",
[
"env",
{
"targets": {
"browsers": "last 2 versions"
},
"loose": true,
"modules": false
}
]
],
"env": {
"test": {
"plugins": ["babel-plugin-transform-es2015-modules-commonjs"]
}
}
}