昨日React=を使用して開始したので、デモアプリをセットアップします。環境は次のとおりです。
Bootstrapスタイルをセットアップしようとしています。
このチュートリアルに従いましたが、TypeScriptに合わせて修正しました。
https://medium.com/@victorleungtw/how-to-use-webpack-with-react-and-bootstrap-b94d3376597
すべてが機能し、ページにサインインフォームが表示され、Bootstrap HTMlがReact-Bootstrapによって出力されます。ただし、スタイルは要素に適用されず、=のない単なるHTMLページですBootstrapスタイルが適用されました。設定に何が欠けているのかわかりません:
webpack.config.js
チュートリアルで述べたようにnpmを介してローダーを追加しましたが、cssからTypeScriptモジュールをセットアップするように調整しました。
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
これがアプリケーションのエントリポイントです。
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
そして、サインインフォームに関連するUI。
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>
);
}
}
使用するwebpackの構成は、中程度の記事とは少し異なります。
中記事では、著者はstyle-loader
とcss-loader
を使用してcss
ファイルを処理します。
module.exports = {
entry: './main.js',
output: { path: __dirname, filename: 'bundle.js' },
module: {
loaders: [
...
{
test: /\.css$/,
loader: "style-loader!css-loader"
},
...
]
},
};
style-loader
は、CSSコードを<style/>
タグに挿入します。それがチュートリアルが機能する理由です
Webpack構成では、typings-for-css-modules-loader
を使用してcssをロードします。このローダーでは、CSSクラス変数名をclassName
に渡す必要があります。
次のようなコードを記述する必要があることを意味します(一部のコードを簡略化する)。
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>
);
}
}
bt[classname]
をclassName
に渡します。
うまくいくと思います。
ところで、typings-for-css-modules-loader
-> link を使用して別のメディア記事を見つけました。
私は同じ問題に遭遇し、これは私のために働いた->
私はbootstrap= npmでインストールしました:
npm i --save bootstrap
次に、index.js
(App.jsをレンダリングする)で、nodes_modulesからブートストラップの縮小されたcssファイルを次のようにインポートしました。
import '../node_modules/bootstrap/dist/css/bootstrap.min.css';
レスポンシブなポジショニングが機能するようになりました(以前と同じようにreact-bootstrap
が正しいクラス名をレンダリングしていますが、スタイルは設定されていません)。
注: https://react-bootstrap.github.io/getting-started/introduction は、index.html
の先頭にcssを追加する必要があることを示しています。この方法で成功しませんでした。
現時点で関連性があるかどうかはわかりませんが、投稿を確認しました。ただし、 react-bootstrap に従って、react-bootstrapを使用できます。「<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.2.1/css/bootstrap.min.css" integrity="sha384-GJzZqFGwb1QTTN6wy59ffF1BuGJpLSa9DkKMp0DgiMDm4iYMj70gZWKYbI706tWS" crossorigin="anonymous" />
」を追加する必要があります
これをindex.htmlヘッダータグに追加しました。
また、app.jsにimport "react-bootstrap/dist/react-bootstrap.min.js";
も追加しました。
最初にする必要があるのはInstall Bootstrap using NPM
npm install --save bootstrap
それから
ブートストラップを使用する必要があるコンポーネントでこのステートメントを記述してください、これは私の場合に機能します。
import 'bootstrap/dist/css/bootstrap.css';
CSSスタイリングが機能し始めます。 :)
ハッピーコーディング!