我用Webpack将所有的npm模块打包。这是我的webpack.config.js文件:
这里是我所提到的main.js文件。正如您所看到的,我试图导入React、React-dom、fixed-data-table、chartjs、jquery和visjs。
这导致我的浏览器开发工具显示错误:未捕获的引用错误:React未定义。
在打包过程中我做错了什么?我假设打包过程没问题,因为没有错误。但是我如何正确地在另一个.js文件中导入React等内容?
这是我的package.json文件:
"use strict";
module.exports = {
entry: './main.js',
output: { path: __dirname, filename: 'bundle.js' },
module: {
loaders: [
{
test: /.js?$/,
loader: 'babel-loader',
exclude: /node_modules/,
query: {
presets: ['es2015', 'react']
}
},
{test: /\.json$/, loader: "json"},
]
},
};
这里是我所提到的main.js文件。正如您所看到的,我试图导入React、React-dom、fixed-data-table、chartjs、jquery和visjs。
import React from 'react';
import ReactDOM from 'react-dom';
import {Table, Column, Cell} from 'fixed-data-table';
import Chart from 'chartjs';
import jquery from 'jquery';
import vis from 'vis';
一切都很好,我从我的index.html中删除了react、chartjs、jquery等源代码,并只引用了新创建的bundle.js。
在我的功能性.js文件中,我的内容和react类派生自此文件,在开头添加以下内容(我认为错误源自此)
import React from './bundle';
import ReactDOM from './bundle';
import {Table, Column, Cell} from './bundle';
import Chart from './bundle';
import vis from './bundle';
这导致我的浏览器开发工具显示错误:未捕获的引用错误:React未定义。
在打包过程中我做错了什么?我假设打包过程没问题,因为没有错误。但是我如何正确地在另一个.js文件中导入React等内容?
这是我的package.json文件:
{
"name": "test",
"version": "1.0.0",
"description": "",
"main": "main.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "",
"license": "ISC",
"devDependencies": {
"babel-core": "^6.3.17",
"babel-loader": "^6.2.0",
"babel-preset-es2015": "^6.3.13",
"babel-preset-react": "^6.3.13",
"babel-runtime": "^6.3.19",
"chartjs": "^0.3.24",
"webpack": "^1.12.9"
},
"dependencies": {
"chartjs": "^0.3.24",
"fixed-data-table": "^0.6.0",
"react": "^0.14.3",
"react-dom": "^0.14.3",
"vis": "^4.17.0"
}
}