使用babel / webpack捆绑反应/打字稿

时间:2020-03-22 03:27:18

标签: asp.net reactjs typescript webpack babeljs

我有一个使用Typescript并进行反应的ASP.Net MVC项目,我正尝试使用webpack和babel捆绑文件。

在打字稿中,我必须导出我的组件才能在多个文件中使用它们。 所有这些都可以很好地链接在一起,但这意味着最终.jsx文件中有导出声明。

当我尝试将输出.jsx与webpack捆绑在一起时,出现以下错误 Error: Plugin/Preset files are not allowed to export objects, only functions.

我尝试安装了多个babel插件,这些插件据说可以解决这个问题,但是没有任何运气。

我觉得我缺少什么。 如何删除这些出口申报单,或使babel变得更好? 谢谢

VehiclePanel.tsx

import { Component } from 'react';
import { IVehicle } from "../../Interfaces/Interfaces";

export class VehiclePanel extends Component<IVehicle> {

    constructor(props) {
        super(props);
    }

    render() {
        return (
            <div className="box">
                <div className="box-header with-border">
                    <h3 className="box-title">{this.props.VehicleName}</h3>
                    <div className="box-tools pull-right" style={{ marginTop: "-20px" }}>
                        <h3><a href="NewService"><span className="label label-primary">New Service</span></a>
                        <a href={"EditVehicle/" + this.props.VehicleGuid}><span className="label label-primary">Edit</span></a></h3>
                    </div>
                </div>
                <div className="box-body">
                    VIN:                           <div className="box-tools pull-right"> Service Due Date: </div><br/>
                    {this.props.Vin}               <div className="box-tools pull-right"> {this.props.ServiceDueDate}  </div><br/><br/>
                    Fire Extinguisher:             <div className="box-tools pull-right"> Fire Extinguisher Inspection Due:</div><br/>
                    {this.props.FireExtinguisherSerial}  <div className="box-tools pull-right"> {this.props.FireExtinguisherInspectionDueDate}  </div><br/><br/>
                    Person Responsible:            <div className="box-tools pull-right"> Last Inspected:   </div><br/>
                    {this.props.PersonResponsible} <div className="box-tools pull-right"> {this.props.LastInspected}  </div>
                </div>
                <div className="box-footer"></div>
            </div>
        );
    }
}

VehiclePage.tsx (使用VehiclePanel)

import * as React from 'react';
import * as ReactDOM from 'react-dom';
import { IVehicle } from "../../Interfaces/Interfaces";
import { VehiclePanel } from '../General/VehiclePanel';

interface IVehiclePageProps {
    data: IVehicle[];
}

interface IVehiclePageState {
    data: IVehicle[];
}

class VehiclesPage extends React.Component<IVehiclePageProps, IVehiclePageState> {

    constructor(props) {
        super(props);
    }

    componentWillMount() {
        this.setState({ data: this.props.data });
    }

    render() {
        var vehiclePanels = this.state.data.map(function (vehicle) {
            console.log(vehicle);
            return (<VehiclePanel
                Vin={vehicle.Vin}
                ArchivedDate={vehicle.ArchivedDate}
                ServiceDueDate={vehicle.ServiceDueDate}
                FireExtinguisherSerial={vehicle.FireExtinguisherSerial}
                FireExtinguisherInspectionDueDate={vehicle.FireExtinguisherInspectionDueDate}
                PersonResponsible={vehicle.PersonResponsible}
                LastInspected={vehicle.LastInspected}
                VehicleGuid={vehicle.VehicleGuid}
                Description={vehicle.Description}
                KmsHrs={vehicle.KmsHrs}
                VehicleName={vehicle.VehicleName} />);
        });

        return (
            <div className="commentBox">
                <section className="content-header">
                    <h1>
                    Vehicles
                    <small>Vehicles description</small>
                    <div className="box-tools pull-right">
                        <a href="/EditVehicle/00000000-0000-0000-0000-000000000000"><span className="label label-primary">Add</span></a>
                    </div>
                    </h1>
                </section>
                <section className="content container-fluid">
                    {vehiclePanels}
                </section>
            </div>
        );
    }
}
ReactDOM.render(<VehiclesPage data={(JSON.parse((document.getElementById('JSON') as HTMLInputElement).value) as IVehicle[])} />, document.getElementById('content'));

VehiclePanel.jsx (输出,文件顶部)

import { Component } from 'react';
export class VehiclePanel extends Component {
    constructor(props) {
        super(props);
    }

webpack.config.js

const path = require('path');
const webpack = require('webpack');

const jsxConfig = {
    plugins: [
        new webpack.HotModuleReplacementPlugin(),
        new webpack.ProvidePlugin({
            'jquery': 'jquery'
        }),
        new webpack.ProvidePlugin({
            'React': 'react'
        }),
    ],
    resolve: {
        extensions: ['.js', '.jsx', '.css'],
    },
    node: {
        fs: "empty",
        module: "empty"
    },
    module: {
        rules: [
            {
                test: /\.(js|jsx)$/,
                exclude: /node_modules/,
                use: {
                    loader: "babel-loader",
                    options: {
                        presets: ['react']
                    }
                },
            },
            {
                test: /\.css$/,
                use: ['style-loader', 'css-loader']
            }
        ]
    },
    //mode: 'development'
    mode: 'production'
}


const vehicles = Object.assign({}, jsxConfig, {
    entry: './built/Components/Vehicles/VehiclePage.jsx',
    output: { filename: 'vehicles.jsx', path: path.resolve(__dirname, 'Content/dist/js'), },
});


const editVehicle = Object.assign({}, jsxConfig, {
    entry: './built/Components/Vehicles/EditVehiclePage.jsx',
    output: { filename: 'editVehicle.jsx', path: path.resolve(__dirname, 'Content/dist/js'), },
});


module.exports = [ vehicles, editVehicle ];

tsconfig.json

{
  "compileOnSave": true,
  "compilerOptions": {
    "outDir": "./built",
    "allowJs": true,
    "target": "ESNext",
    "jsx": "preserve",
    "lib": [ "es2015", "es2016", "dom" ],
    "module": "ESNext",
    "moduleResolution": "Node",
    "noUnusedLocals": true,
    "noUnusedParameters": true
  },
  "include": [
    "./Scripts/Components/**/*"
  ],
  "exclude": [
    "./Scripts/Interfaces/*"
  ]
}

0 个答案:

没有答案