我正在使用yarn
而不是npm
从头开始构建反应应用程序,因为纱线比npm快。我没有使用create-react-app
命令来创建我的React应用,只是为了确保我从头开始做所有事情。
我有一个Webpack文件,其中包含从webpack site复制的基本配置代码段。
请注意,由于我的节点babel-node
文件中有ES6 import
,因此我正在使用server.js
来运行项目。
在下面的文件中,要告诉pm2
使用babel-node
而不是常规node
,请使用解释器
{
"name": "advanced-react",
"version": "1.0.0",
"main": "lib/server.js",
"author": "GopiGorantala",
"license": "MIT",
"scripts": {
"dev": "pm2 start lib/server.js --watch --interpreter babel-node"
},
"babel": {
"presets": [
"react",
"env",
"stage-2"
]
},
"devDependencies": {
"babel-eslint": "^10.0.1",
"eslint": "^5.13.0",
"eslint-plugin-react": "^7.12.4"
},
"dependencies": {
"babel-preset-env": "^1.7.0",
"babel-preset-react": "^6.24.1",
"babel-preset-stage-2": "^6.24.1",
"ejs": "^2.6.1",
"express": "^4.16.4",
"pm2": "^3.2.9"
}
}
import express from 'express';
import config from './config';
const app = express();
app.use(express.static('public'));
app.set('view engine', 'ejs');
app.get('/', (req, res) => {
res.render('index', {answer: 42});
});
app.listen(config.port, function listenHandler() {
console.info(`running on ${config.port}`);
});
当我使用yarn dev
运行应用程序时,我没有使服务器联机,而是获得了errored
我尝试使用yarn pm2 logs
检查日志以检查错误,但没有得到太多信息。请参见下面的屏幕截图
注意:请注意,我正在使用yarn add --dev
命令添加我的软件包
问题:我收到spawn babel-node ENOENT
错误。我该如何确保自己不会遇到这个问题。
答案 0 :(得分:1)
并非所有的webpack配置都可以与jsx一起使用。 WP应该看起来像这样。
module.exports = {
entry: './src/index.js',
module: {
rules: [
{
test: /\.(js|jsx)$/,
exclude: /node_modules/,
use: ['babel-loader']
}
]
},
resolve: {
extensions: ['*', '.js', '.jsx']
},
output: {
path: __dirname + '/dist',
publicPath: '/',
filename: 'bundle.js'
},
devServer: {
contentBase: './dist'
}
};
答案 1 :(得分:1)
答案 2 :(得分:1)
如果您使用的是最新的babel(^ 7.0.0),则应通过以下方式安装“ babel-node”:
sudo npm i -g @babel/node
请勿通过这种方式安装,因为它仅适用于babel 6:
npm install -g babel-cli
文档看起来已经过时,并且适用于babel 6版本。