Dans mon application reactJS - j'inclue tous les fichiers .scss dans un fichier main.scss - sous le dossier styles dans le dossier src. J'ai la configuration de webpack suivante. essayé d'inclure le fichier main.scss directement dans mon composant principal - obtenir l'erreur à '@ import' où j'importe d'autres fichiers scss. si j'insère des styles de fichiers scss distincts, ça va - mais comment faire fonctionner ça avec un fichier main.scss et comment l'inclure?ReactJS - y compris d'autres fichiers scss dans main.scss
erreur: jeton inattendu, attendus ((1: 8)
1 | @import 'mycomponent';
module.exports = {
entry: [
'webpack-hot-middleware/client',
path.resolve(__dirname, 'src'),
],
output: {
path: path.resolve(__dirname, 'src'),
filename: 'bundle.js',
publicPath: '/',
},
plugins: [
new ExtractTextPlugin('bundle.css', { allChunks: true }),
new webpack.HotModuleReplacementPlugin(),
new webpack.NamedModulesPlugin(),
new webpack.DefinePlugin({
'process.env': {
NODE_ENV: JSON.stringify('development'),
WEBPACK: true,
},
}),
],
module: {
rules: [
{
enforce: 'pre',
test: /\.js$/,
exclude: /node_modules/,
loader: 'eslint-loader',
},
{
test: /\.js$/,
exclude: /node_modules/,
use: {
loader: 'babel-loader',
query: {
presets: ['react-hmre'],
},
},
include: path.resolve(__dirname, 'src'),
},
{
use: ExtractTextPlugin.extract({
fallback: "style-loader",
use: [
'css-loader',
'sass-loader?outputStyle=expanded'.
]
}),
test: /\.scss$/,
exclude: /node_modules/
}
],
},
};
index.js
import React from 'react';
import { render } from 'react-dom';
import { createBrowserHistory } from 'history';
import { ConnectedRouter, routerMiddleware } from 'react-router-redux';
import { Provider } from 'react-redux';
import { createStore, applyMiddleware } from 'redux';
import App from './components/homepage';
import reducers from './reducers';
import '../styles/main.scss';
const history = createBrowserHistory();
const store = createStore(reducers, applyMiddleware(routerMiddleware(history)));
render(
<Provider store={store}>
<ConnectedRouter history={history}>
<App />
</ConnectedRouter>
</Provider>
, document.getElementById('app'));
if (process.env.NODE_ENV === 'development' && module.hot) {
module.hot.accept();
module.hot.accept('./reducers',() => {
const nextRootReducer = require('./reducers').default; // eslint-disable-line global-require
store.replaceReducer(nextRootReducer(store.asyncReducers));
});
}
pouvez-vous ajouter l'erreur que vous obtenez et la déclaration d'importation s'il vous plaît – bennygenel
https://stackoverflow.com/users/2315280/bennygenel - mis à jour ma question – monkeyjs
Vous devrez transpile votre code de serveur avant de l'exécuter. Vous aurez besoin d'une configuration webpack client et d'une configuration webpack serveur. –