Je viens de commencer à utiliser React hier, donc mettre en place une application de démonstration. L'environnement est:
J'essaie de configurer les styles Bootstrap.
J'ai suivi ce tutoriel tout en le modifiant pour l'adapter à TypeScript:
https://medium.com/@victorleungtw/how-to-use-webpack-with-react-and-bootstrap-b94d3376597
Tout fonctionne, la page affiche le formulaire de connexion et le Bootstrap HTMl est généré par React-Bootstrap. Mais les styles ne sont pas appliqués aux éléments, c'est juste une page HTML simple sans aucun des = Bootstrap styles appliqués. Je ne sais pas ce que je manque dans la configuration:
webpack.config.js
J'ai ajouté les chargeurs via npm comme mentionné dans le tutoriel, mais aussi ajusté pour configurer les modules TypeScript à partir du css.
module.exports = {
entry: {
catalog: "./src/apps/CatalogApp.tsx",
auth: "./src/apps/AuthApp.tsx"
},
output: {
filename: "[name].bundle.js",
publicPath: "/build/",
path: __dirname + "/dist"
},
// Enable sourcemaps for debugging webpack's output.
devtool: "source-map",
resolve: {
// Add '.ts' and '.tsx' as resolvable extensions.
extensions: [".ts", ".tsx", ".js", ".json"]
},
module: {
rules: [
// All files with a '.ts' or '.tsx' extension will be handled by 'awesome-TypeScript-loader'.
{
test: /\.tsx?$/,
loader: "awesome-TypeScript-loader"
},
// All output '.js' files will have any sourcemaps re-processed by 'source-map-loader'.
{
enforce: "pre",
test: /\.js$/,
loader: "source-map-loader"
},
// css loader
{
test: /\.css$/,
loader: "typings-for-css-modules-loader?modules"
},
{
test: /\.(woff|woff2)(\?v=\d+\.\d+\.\d+)?$/,
loader: 'url-loader?limit=10000&mimetype=application/font-woff'
},
{
test: /\.ttf(\?v=\d+\.\d+\.\d+)?$/,
loader: 'url-loader?limit=10000&mimetype=application/octet-stream'
},
{
test: /\.eot(\?v=\d+\.\d+\.\d+)?$/,
loader: 'file-loader'
},
{
test: /\.svg(\?v=\d+\.\d+\.\d+)?$/,
loader: 'url-loader?limit=10000&mimetype=image/svg+xml'
}
]
},
// When importing a module whose path matches one of the following, just
// assume a corresponding global variable exists and use that instead.
// This is important because it allows us to avoid bundling all of our
// dependencies, which allows browsers to cache those libraries between builds.
externals: {
"react": "React",
"react-dom": "ReactDOM"
}
};
AuthApp.tsx
Ceci est mon point d'entrée pour l'application.
import * as React from "react";
import * as ReactDOM from "react-dom";
import { SigninForm } from "../components/users/SigninForm";
import { MiniCart } from '../components/cart/MiniCart';
import { UserMenu } from '../components/users/UserMenu';
import * as bs from 'bootstrap/dist/css/bootstrap.css';
import * as bst from 'bootstrap/dist/css/bootstrap-theme.css';
if (document.getElementById("signin-form")) {
ReactDOM.render(
<SigninForm />,
document.getElementById("signin-form")
);
}
if (document.getElementById('cart')) {
ReactDOM.render(
<MiniCart />,
document.getElementById('cart')
);
}
if (document.getElementById('user-menu')) {
ReactDOM.render(
<UserMenu />,
document.getElementById('user-menu')
);
}
SigninForm.tsx
Et l'interface utilisateur pertinente pour le formulaire de connexion.
import * as React from 'react';
import * as ReactDOM from "react-dom";
import { Button, Col, Row } from 'react-bootstrap';
import { Spinner } from '../shared/Spinner';
interface SigninFormProps {
}
interface SigninFormState {
email: string;
password: string;
}
export class SigninForm extends React.Component<SigninFormProps, SigninFormState> {
constructor(props: SigninFormProps) {
super(props);
this.state = {
email: '',
password: ''
};
this.handleChange = this.handleChange.bind(this);
this.handleSubmit = this.handleSubmit.bind(this);
}
handleChange(event: any) {
this.setState({ [event.target.name]: event.target.value });
}
handleSubmit(event: any) {
event.preventDefault();
console.log('Submitting form', this.state);
}
render() {
return (
<Row>
<Col md={8}>
<form className="signin-form" onSubmit={this.handleSubmit}>
<div className="form-group">
<label htmlFor="email">Email</label>
<input id="email" name="email" type="email" value={this.state.email} onChange={this.handleChange} />
</div>
<div className="form-group">
<label htmlFor="password">Password</label>
<input id="password" name="password" type="password" value={this.state.password} onChange={this.handleChange} />
</div>
<Button>Submit</Button>
</form>
</Col>
<Col md={4}>
Right Side
</Col>
</Row>
);
}
}
La configuration Webpack que vous utilisez est un peu différente de l'article moyen.
Dans l'article moyen, l'auteur utilise style-loader
et css-loader
pour traiter le fichier css
.
module.exports = {
entry: './main.js',
output: { path: __dirname, filename: 'bundle.js' },
module: {
loaders: [
...
{
test: /\.css$/,
loader: "style-loader!css-loader"
},
...
]
},
};
style-loader
injectera le code CSS dans <style/>
tag. Voilà pourquoi le tutoriel fonctionne
Dans votre configuration de webpack, vous utilisez typings-for-css-modules-loader
pour charger css. Avec ce chargeur, vous devez passer le nom de la variable de classe css à className
.
Cela signifie que vous devez écrire le code comme (simplifier du code):
import * as React from "react";
import * as bs from 'bootstrap/dist/css/bootstrap.css';
import * as bst from 'bootstrap/dist/css/bootstrap-theme.css';
import { Button, Col, Row } from 'react-bootstrap';
import { Spinner } from '../shared/Spinner';
export class SigninForm extends React.Component {
...
render() {
return (
<Row>
<Col md={8}>
<form className={bt["signin-form"]} onSubmit={this.handleSubmit}>
<div className={bt["form-group"]}>
<label htmlFor="email">Email</label>
<input id="email" name="email" type="email" value={this.state.email} onChange={this.handleChange} />
</div>
<Button>Submit</Button>
</form>
</Col>
<Col md={4}>
Right Side
</Col>
</Row>
);
}
}
Passer bt[classname]
à className
.
Je pense que cela va fonctionner.
btw, je trouve un autre article moyen utilisant typings-for-css-modules-loader
-> lien .
Je suis tombé sur le même problème et cela a fonctionné pour moi ->
J'ai fini par installer bootstrap avec npm:
npm i --save bootstrap
Puis dans index.js
(où je rend App.js) J'ai importé le fichier CSS minifié de bootstrap à partir de nodes_modules comme ceci:
import '../node_modules/bootstrap/dist/css/bootstrap.min.css';
Maintenant, le positionnement réactif fonctionne (où comme avant, j'ai vu react-bootstrap
rendu des noms de classe corrects, mais sans style).
Remarque: https://react-bootstrap.github.io/getting-started/introduction indique que vous devez ajouter le CSS à la tête de index.html
. Je n'ai pas réussi à le faire de cette façon.
Je ne sais pas si c'est pertinent en ce moment, j'ai vérifié votre message. Cependant, je suis capable d'utiliser react-bootstrap, selon react-bootstrap , vous devrez ajouter "<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.2.1/css/bootstrap.min.css" integrity="sha384-GJzZqFGwb1QTTN6wy59ffF1BuGJpLSa9DkKMp0DgiMDm4iYMj70gZWKYbI706tWS" crossorigin="anonymous" />
que j'ai ajouté dans ma balise d'en-tête index.html.
Et j'ai également ajouté import "react-bootstrap/dist/react-bootstrap.min.js";
dans mon app.js.
Tout d'abord, vous devez Installer Bootstrap en utilisant NPM
npm install --save bootstrap
ensuite
allez pour écrire cette déclaration dans quel composant vous devez utiliser le bootstrap, cela fonctionne dans mon cas.
import 'bootstrap/dist/css/bootstrap.css';
Le style CSS commencera à fonctionner. :)
Codage heureux!