编译的带有browserify的React和babel表示:ReferenceError:未定义React

时间:2018-12-06 14:27:13

标签: javascript reactjs babeljs browserify

问题:没有构建错误,但是当尝试在浏览器上使用该文件时,控制台显示:ReferenceError: React is not defined

使用以下两个命令编译react文件:

npx browserify \
-t [ babelify --presets [ @babel/preset-react @babel/preset-env ] ] \
./input.jsx -o ./temp1.js

然后:

npx babel ./temp1.js \
--presets=@babel/preset-react,@babel/preset-env,minify \
--no-comments --out-file ./output.js

我的input.jsx文件如下:

import react from 'react';
import Testing from './component/testing.jsx'
import reactDOM from 'react-dom';

reactDOM.render
(
    <Testing></Testing>,
    document.getElementById('root')
);

./component/testing.jsx看起来像这样:

import React from 'react';

class Testing extends React.Component
{
    render()
    {
        return (
            <h1>Hello World</h1>
        );
    }
}

export default Testing;

package.json /版本:

{
"dependencies": {
    "react": "^16.6.3",
    "react-dom": "^16.6.3"
},
"devDependencies": {
    "@babel/cli": "^7.2.0",
    "@babel/core": "^7.2.0",
    "@babel/preset-env": "^7.2.0",
    "@babel/preset-react": "^7.0.0",
    "babel-preset-minify": "^0.5.0",
    "babel-preset-react": "^6.24.1",
    "babelify": "^10.0.0",
    "browserify": "^16.2.3"
}
}

节点:v10.9.0
NPM:6.2.0

1 个答案:

答案 0 :(得分:1)

我认为您有一个命名问题。在此导入语句(input.jsx)上:

import react from 'react';

react的{​​{1}}更改为