Jestem nowym użytkownikiem Webpack 2 i jest to leniwe ładowanie, do tej pory stworzyłem projekt bez leniwego ładowania i dzielenia kodu, ale teraz chcę podzielić mój kod na porcje i użyj importu systemu z React Router. Stworzyłem część React Router zgodnie z this artykułKonfiguracja Webpack 2 do drżenia drzewa i leniwego ładowania z System.import w projekcie React
ten plik konfiguracyjny 2 jest poniżej.
let webpack = require('webpack');
let path = require('path');
let ExtractTextPlugin = require('extract-text-webpack-plugin');
var devFlagPlugin = new webpack.DefinePlugin({
__DEV__: JSON.stringify(JSON.parse(process.env.DEBUG || 'false')),
'process.env': {
NODE_ENV: JSON.stringify(process.env.NODE_ENV || 'development'),
}
});
let extractSCSS = new ExtractTextPlugin('[name].css')
module.exports = {
context: __dirname,
entry: {
bundle: './src/app/app-client.jsx',
styles: './src/app/sass/main.scss',
vendor: [
'react', 'react-dom'
]
},
output: {
filename: '[name].js',
chunkFilename: 'chunk.[id].[chunkhash:8].js',
path: './src/build',
},
resolve: {
extensions: ['.js', '.jsx']
},
devtool: 'cheap-module-source-map',
module : {
rules : [
{
test: /\.scss$/,
loader: extractSCSS.extract(['css-loader','sass-loader'])
},
{
test: /\.jsx?$/,
exclude: [/node_modules/, /libs/],
use: {
loader: "babel-loader",
query: {
presets: ['es2015', 'react', 'stage-2' ],
plugins: [ "transform-runtime" ]
}
}
},
{
test: /\.woff2?$|\.ttf$|\.eot$|\.svg$|\.png|\.jpe?g|\.gif$/,
use: {
loader:'file-loader'
}
}
]
},
plugins: [
extractSCSS,
devFlagPlugin,
new webpack.optimize.CommonsChunkPlugin({
name: 'bundle',
children: true,
async: true,
minChunks: 2
}),
new webpack.optimize.CommonsChunkPlugin({
name: 'vendor',
children: true,
async: true,
minChunks: 2
})
]
}
ale WebPack tworzy tylko dwa pliki, sprzedawca i paczkę, również wielkość pakietu nie został zredukowany po I i oddzielone React React DOM.
to są moje trasy.
import App from './App.jsx';
function errorLoading(err) {
console.error('Dynamic page loading failed', err);
}
function loadRoute(cb) {
return (module) => cb(null, module.default);
}
export default {
component: App,
childRoutes: [
{
path: 'stock/info/:symbol(/:tab)',
getComponent(location, cb) {
System.import('./StockPage')
.then(loadRoute(cb))
.catch(errorLoading);
}
},
{
path: '*',
getComponent(location, cb) {
System.import('./NoMatch')
.then(loadRoute(cb))
.catch(errorLoading);
}
}
]
};
moja aplikacja działa, ale leniwy załadunku nie działa oczywiście, bo nie mam żadnych fragmentów moich modułów wewnątrz System.import
.
Proszę, pomóż mi utworzyć właściwą konfigurację webpacka dla wydajności mojej aplikacji! Z góry dziękuję i przepraszam, jeśli coś jest nonsensem, ponieważ jestem nowy w pakiecie sieci Web.
to jest właściwy sposób korzystać z importu dynamicznych w WebPacka 2. – hazardous
Właściwie dla WebPacka you” Potrzebuję [babel-plugin-dynamic-import-webpack] (https://github.com/airbnb/babel-plugin-dynamic-import-webpack), aby przekształcić instrukcje import() zamiast babel-plugin-syntax- dynamiczny import. babel-plugin-syntax-dynamic-import pozwala tylko babelowi na parsowanie importów dynamicznych, ale ich nie przekształca. – vsjn3290ckjnaoij2jikndckjb
@ismay jest prawdziwe dla WebPack V1, ale Webpack2 obsługuje teraz funkcję importowania i importowania() ES6 natywnie. – DanielD