„Możesz potrzebować odpowiedniego programu ładującego do obsługi tego typu plików” z Webpack i Babel

106

Próbuję użyć WebPacka z Babel do skompilowania zasobów ES6, ale otrzymuję następujący komunikat o błędzie:

You may need an appropriate loader to handle this file type.
| import React from 'react';
| /*
| import { render } from 'react-dom'

Oto jak wygląda moja konfiguracja Webpack:

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

module.exports = {
  entry: './index',
  output: {
    path: path.join(__dirname, 'dist'),
    filename: 'bundle.js',
    publicPath: '/dist/'
  },
  module: {
    loaders: [
      {
        test: /\.jsx?$/,
        loader: 'babel-loader',
        exclude: /node_modules/
      }
    ]
  }
}

Oto krok oprogramowania pośredniego, który wykorzystuje Webpack:

var webpack = require('webpack');
var webpackDevMiddleware = require('webpack-dev-middleware');
var config = require('./webpack.config');

var express = require('express');
var app = express();
var port = 3000;

var compiler = webpack(config);
app.use(webpackDevMiddleware(compiler, {
  noInfo: true,
  publicPath: config.output.publicPath
}));

app.get('/', function(req, res) {
  res.sendFile(__dirname + '/index.html');
});

app.listen(port, function(err) {
  console.log('Server started on http://localhost:%s', port);
});

Wszystko, co robi mój plik index.js, to importowanie, ale wygląda na to, że „program ładujący babel” nie działa.

Używam 'babel-loader' 6.0.0.

egidra
źródło
1
Mam ten sam problem. babel-preset-es2015 jest zainstalowany, ale nadal ma problemy z używaniem JSX w wywołaniu ReactDOM.render (): s
SomethingOn
Jakie są rozszerzenia Twojego pliku? Czy są to pliki js czy jsx? Twój program ładujący bierze pod uwagę tylko pliki z rozszerzeniami jsx, to może być problem
cubbuk
Pod tym linkiem twój problem zostanie rozwiązany w 100% [ stackoverflow.com/questions/50149729/…
Mehrdad Masoumi
Pod tym linkiem Twój problem zostanie rozwiązany w 100%. Import css do next.js
Mehrdad Masoumi

Odpowiedzi:

86

Musisz zainstalować es2015ustawienie wstępne:

npm install babel-preset-es2015

a następnie skonfiguruj babel-loader:

{
    test: /\.jsx?$/,
    loader: 'babel-loader',
    exclude: /node_modules/,
    query: {
        presets: ['es2015']
    }
}
loganfsmyth
źródło
37
Mam zainstalowane presety i zainstalowany program ładujący babel. Nadal daje ten sam błąd
Umang Gupta
@UG_ Będziesz musiał zadać osobne pytanie. Musielibyśmy zobaczyć całą konfigurację i pełny komunikat o błędzie.
loganfsmyth
1
@UG_ znalazłeś rozwiązanie?
Sarasranglt
34

Upewnij się, że masz zainstalowane ustawienie wstępne babel es2015 .

Przykładowy pakiet package.json devDependencies jest:

"devDependencies": {
  "babel-core": "^6.0.20",
  "babel-loader": "^6.0.1",
  "babel-preset-es2015": "^6.0.15",
  "babel-preset-react": "^6.0.15",
  "babel-preset-stage-0": "^6.0.15",
  "webpack": "^1.9.6",
  "webpack-dev-middleware": "^1.2.0",
  "webpack-hot-middleware": "^2.0.0"
},

Teraz skonfiguruj program ładujący babel w konfiguracji swojego pakietu internetowego:

{ test: /\.js$/, loader: 'babel-loader', exclude: /node_modules/ }

dodaj plik .babelrc do katalogu głównego projektu, w którym znajdują się moduły węzłów:

{
  "presets": ["es2015", "stage-0", "react"]
}

Więcej informacji:

svnm
źródło
1
. babelrc jest tym, czego mi brakowało, dzięki! To jest kompletny samouczek, zaakceptowana odpowiedź prowadzi tylko do tej pory.
Mike
Informacja boczna: Nie jestem pewien co do "stage-0" w opcjach (można to również skonfigurować w .babelrc): Niektóre funkcje mogą nie być zgodne z oficjalnymi standardami ES, więc zwykle używam bezpieczniejszego "stage-3".
Christof Kälin
11

Jeśli używasz Webpack> 3, musisz tylko zainstalować babel-preset-env, ponieważ to ustawienie wstępne obejmuje es2015, es2016 i es2017.

var path = require('path');
let webpack = require("webpack");

module.exports = {
    entry: {
        app: './app/App.js',
        vendor: ["react","react-dom"]
    },
    output: {
        filename: 'bundle.js',
        path: path.resolve(__dirname, '../public')
    },
    module: {
        rules: [{
            test: /\.jsx?$/,
            exclude: /node_modules/,
            use: {
                loader: 'babel-loader?cacheDirectory=true',
            }
        }]
    }
};

To pobiera konfigurację z mojego .babelrcpliku:

{
    "presets": [
        [
            "env",
            {
                "targets": {
                    "browsers":["last 2 versions"],
                    "node":"current"
                }
            }
        ],["react"]
    ]
}
Panie Doomsbuster
źródło
1

Ze względu na aktualizacje i zmiany w godzinach nadliczbowych, zgodność wersji zaczyna powodować problemy z konfiguracją.

Twój plik webpack.config.js powinien wyglądać tak, jak ten, możesz również skonfigurować sposób dopasowania.

var path = require('path');
var webpack = require("webpack");

module.exports = {
  entry: './src/js/app.js',
  devtool: 'source-map',
    mode: 'development',
  module: {
    rules: [{
      test: /\.js$/,
      exclude: /node_modules/,
      use: ["babel-loader"]
    },{
      test: /\.css$/,
      use: ['style-loader', 'css-loader']
    }]
  },
  output: {
    path: path.resolve(__dirname, './src/vendor'),
    filename: 'bundle.min.js'
  }
};

Kolejną rzeczą do zauważenia jest zmiana argumentów, powinieneś przeczytać dokumentację Babel https://babeljs.io/docs/en/presets

.babelrc

{
    "presets": ["@babel/preset-env", "@babel/preset-react"]
}

Uwaga: musisz się upewnić, że masz zainstalowane powyższe zależności @ babel / preset-env & @ babel / preset-aware w swoim pakiecie.

Delino
źródło
1
Dodanie @babel/preset-reactnaprawiło to dla mnie.
kyw
1

AKTUALIZACJA ZESPOŁU BABEL:

Jesteśmy bardzo podekscytowani, że próbujesz użyć składni ES2015, ale zamiast kontynuować coroczne ustawienia wstępne, zespół zaleca użycie babel-preset-env. Domyślnie zachowuje się tak samo, jak poprzednie ustawienia wstępne kompilacji ES2015 + do ES5

Jeśli używasz Babel w wersji 7 , będziesz musiał uruchomić npm install @ babel / preset-env i mieć w swojej .babelrckonfiguracji "presets": ["@ babel / preset-env"] .

Spowoduje to kompilację wszystkich najnowszych funkcji do wersji es5 kodu es5:

Wymagania wstępne :

  1. Webpack 4+
  2. Babel 7+

Krok 1: npm install --save-dev @ babel / preset-env

Krok 2: W celu skompilowania JSXkodu do es5, babel dostarcza @babel/preset-reactpakiet do konwersji,jsx pliku rozszerzenia na zrozumiały kod natywnej przeglądarki.

Krok 3: npm install --save-dev @ babel / preset-act

Krok 4: Utwórz .babelrcplik w ścieżce głównej projektu, jeśli webpack.config.jsistnieje.

{
  "presets": ["@babel/preset-env", "@babel/preset-react"]
}

Krok 5: webpack.config.js

const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');

module.exports = {
    mode: 'development',
    entry: path.resolve(__dirname, 'src/index.js'),
    output: {
        path: path.resolve(__dirname, 'output'),
        filename: 'bundle.js'
    },
    resolve: {
        extensions: ['.js', '.jsx']
    },
    module: {
        rules: [{
                test: /\.(js|jsx)$/,
                exclude: /node_modules/,
                use: {
                    loader: 'babel-loader'
                }
            },
            {
                test: /\.css$/i,
                use: ['style-loader', 'css-loader'],
            }
        ]
    },
    plugins: [
        new HtmlWebpackPlugin({
            template: "./public/index.html",
            filename: "./index.html"
         })
    ]
}
khizer
źródło
0

Podczas korzystania z Typescript:

W moim przypadku użyłem nowszej składni pakietu webpack v3.11 z ich strony z dokumentacją, po prostu skopiowałem konfigurację CSS i stylów ładujących z ich strony internetowej. Przekomentowany kod (nowsze API) powoduje ten błąd, patrz poniżej.

  module: {
        loaders: [{
                test: /\.ts$/,
                loaders: ['ts-loader']
            },
            {
                test: /\.css$/,
                loaders: [
                    'style-loader',
                    'css-loader'
                ]
            }
        ]
        // ,
        // rules: [{
        //     test: /\.css$/,
        //     use: [
        //         'style-loader',
        //         'css-loader'
        //     ]
        // }]
    }

Właściwy sposób to ująć to:

    {
        test: /\.css$/,
        loaders: [
            'style-loader',
            'css-loader'
        ]
    }

w tablicy właściwości loaders.

Legendy
źródło
0

Ten rzuca mi na przejażdżkę. Angular 7, Webpack Znalazłem ten artykuł, więc chcę go przypisać https://www.edc4it.com/blog/web/helloworld-angular2.html

Jakie jest rozwiązanie: // w pliku komponentu. użyj szablonu jako pakietu internetowego, potraktuje go jako szablon tekstowy: require ('./ process.component.html')

aby karma to zinterpretowała npm install dodaj html-loader --save-dev {test: /.html$/, użyj: "html-loader"},

Mam nadzieję, że to komuś pomoże

Oliver Champet
źródło