Building Server Teil von (React) isomorphic Webapp mit Webpack inklusive Style-Loader für CSS

Ich versuche, eine React-Anwendung zu erstellen, die ich isomorph entwickle. Einer derbekannte Probleme dabei Ist das Webpack Loader ermöglichenimport/require von Nicht-Javascript-Assets wie CSS-Dateien. z.B

// ExampleComponent.jsx
import Select from 'react-select';
import 'react-select/dist/react-select.css';

Wenn eine Anwendung mit Express erstellt wird, gelangt der Knoten zu diesem Import und schlägt fehl, da keine CSS-Datei verarbeitet werden kann. Es wird nur Javascript erwartet (und dankbabel-register JSX).

ine Möglichkeit, dies zu umgehen, besteht darin, das @ zu verwendetarget: 'node' -Option im Webpack beim Erstellen der Serveranwendung (die alle allgemeinen Teile wie die Komponenten enthält, da es sich um eine isomorphe App handelt), um den serverseitigen Code zu erstellen. Dies sollte zu einem @ führserver.js wird erstellt und kann dann vom Knoten ausgeführt werden.

Hinweis: Ich weiß, dass es andere Möglichkeiten gibt, um dieses spezielle Problem zu umgehen (z. B. die Nichtverwendung vonimport/require um alles einzuschließen, was nicht jav ist, ascript, aber in dieser Entwicklungsphase in dieser Anwendung noch nicht praktikabel ist.

// webpack.config.js
var webpack = require('webpack');
var path = require('path');

module.exports = [
  // Client build
  {
    entry: {
      'bundle.min': [
        'bootstrap-webpack!./bootstrap.config.js',
        'babel-polyfill',
        './client/index.jsx'
      ],
      'bundle': [
        'bootstrap-webpack!./bootstrap.config.js',
        'babel-polyfill',
        './client/index.jsx'
      ]
    },
    output: {
      path: './dist',
      filename: '[name].js'
    },
    plugins: [
      new webpack.optimize.UglifyJsPlugin({
        include: /\.min\.js$/,
        minimize: true
      })
    ],
    module: {
      loaders: [
        {
          test: /\.jsx$/,
          loader: 'babel-loader',
          exclude: /node_modules/,
          query: {
            plugins: ['transform-runtime'],
            presets: ['react', 'es2015', 'stage-0']
          }
        },
        {
          test: /\.js$/,
          loader: 'babel-loader',
          exclude: /node_modules/,
          query: {
            plugins: ['transform-runtime'],
            presets: ['es2015', 'stage-0']
          }
        },
        {
          test: /\.css$/,
          loader: 'style-loader!css-loader'
        },
        { test: /\.png$/,
          loader: "url-loader?limit=100000"
        },

        // Bootstrap
        {
          test: /\.(woff|woff2)(\?v=\d+\.\d+\.\d+)?$/,
          loader: 'url?limit=10000&mimetype=application/font-woff'},
        {
          test: /\.ttf(\?v=\d+\.\d+\.\d+)?$/,
          loader: 'url?limit=10000&mimetype=application/octet-stream'
        },
        {
          test: /\.eot(\?v=\d+\.\d+\.\d+)?$/,
          loader: 'file'
        },
        {
          test: /\.svg(\?v=\d+\.\d+\.\d+)?$/,
          loader: 'url?limit=10000&mimetype=image/svg+xml'
        }
      ]
    },
    resolve: {
      extensions: ['', '.js', '.jsx', '.json']
    }
  },

  // Server build
  {
    entry: './server/server.jsx',
    target: 'node',
    node: {
      console: false,
      global: false,
      process: false,
      Buffer: false,
      __filename: false,
      __dirname: false,
    },
    output: {
      path: './dist',
      filename: 'server.js',
    },
    module: {
      loaders: [
        {
          test: /\.jsx$/,
          loader: 'babel-loader',
          exclude: /node_modules/,
          query: {
            plugins: ['transform-runtime'],
            presets: ['react', 'es2015', 'stage-0']
          }
        },
        {
          test: /\.js$/,
          loader: 'babel-loader',
          exclude: /node_modules/,
          query: {
            plugins: ['transform-runtime'],
            presets: ['es2015', 'stage-0']
          }
        },
        {
          test: /\.json$/,
          loader: 'json-loader'
        },
        {
          test: /\.css$/,
          loader: 'style-loader!css-loader'
        },
        { test: /\.png$/,
          loader: "url-loader?limit=100000"
        },

        // Bootstrap
        {
          test: /\.(woff|woff2)(\?v=\d+\.\d+\.\d+)?$/,
          loader: 'url?limit=10000&mimetype=application/font-woff'},
        {
          test: /\.ttf(\?v=\d+\.\d+\.\d+)?$/,
          loader: 'url?limit=10000&mimetype=application/octet-stream'
        },
        {
          test: /\.eot(\?v=\d+\.\d+\.\d+)?$/,
          loader: 'file'
        },
        {
          test: /\.svg(\?v=\d+\.\d+\.\d+)?$/,
          loader: 'url?limit=10000&mimetype=image/svg+xml'
        }
      ]
    },
    resolve: {
      extensions: ['', '.js', '.jsx', '.json']
    }
  }
];

Das Problem ist dann, dass der Style-Loader von @ Gebrauch macwindow, das in der Knotenumgebung offensichtlich nicht vorhanden ist.

$ node dist/server.js
/Users/dpwrussell/Checkout/ExampleApp/dist/server.js:25925
            return /msie [6-9]\b/.test(window.navigator.userAgent.toLowerCase());
                                       ^

ReferenceError: window is not defined

VonHie in style-loader.

Es fühlt sich so an, als ob ich kurz davor bin, diese Arbeit zu machen, also wären alle Gedanken willkommen.

Antworten auf die Frage(2)

Ihre Antwort auf die Frage