React應(yīng)用中使用Bootstrap的方法
前言
本節(jié)我們將把bootstrap,font-awesome應(yīng)用到app中,同時創(chuàng)建一個基本的主頁。主要將用到以下包:
- bootstrap-loader及配合工作的一系列l(wèi)oader:bootstrap-sass(bootstrap3) css-loader node-sass sass-loader style-loader url-loader.具體使用見官方文檔
- postcss-loader autoprefixer:自動添加-webkit-box等前綴
- react-bootstrap:在react使用bootstrap組件
bootstrap-loader配置
在webpack的entry入口處添加bootstrap的引用
entry: [
'bootstrap-loader',
path.resolve(projectRootPath,'src/app.js')
]
然后在應(yīng)用目錄下添加.bootstraprc配置文件,對要用到的組件進(jìn)行選擇,怎么配置在官方文檔中有非常詳細(xì)的配置說明及模板??梢灾苯邮褂?。
然后在webpack的配置文件module.loaders中添加css,woff2,tff等文件的加載功能
loaders:[
{
test:/\.js$/,
exclude:/node_modules/,
loader:'babel-loader',
query:{
presets:['es2015','react','stage-0'],
plugins:['transform-decorators-legacy']
}
},
{test:/\.css$/,loader:'style!css'},
{ test: /\.scss$/,
loader: 'style!css?modules&importLoaders=2&sourceMap&localIdentName=[local]___[hash:base64:5]!postcss-loader!sass?outputStyle=expanded&sourceMap'
},
{
test: /\.woff2?(\?v=[0-9]\.[0-9]\.[0-9])?$/,
loader: "url?limit=10000"
},
{
test: /\.(ttf|eot|svg)(\?[\s\S]+)?$/,
loader: 'file'
}
]loaders:[
{
test:/\.js$/,
exclude:/node_modules/,
loader:'babel-loader',
query:{
presets:['es2015','react','stage-0'],
plugins:['transform-decorators-legacy']
}
},
{test:/\.css$/,loader:'style!css'},
{ test: /\.scss$/,
loader: 'style!css?modules&importLoaders=2&sourceMap&localIdentName=[local]___[hash:base64:5]!postcss-loader!sass?outputStyle=expanded&sourceMap'
},
{
test: /\.woff2?(\?v=[0-9]\.[0-9]\.[0-9])?$/,
loader: "url?limit=10000"
},
{
test: /\.(ttf|eot|svg)(\?[\s\S]+)?$/,
loader: 'file'
}
]
最后可以在.bootstraprc中做些css樣式的配置,以替換原來的css,這里簡單介紹幾個:
首先,在src中新建目錄theme用于存放所有與css相關(guān)的文件
preBootstrapCustomizations
定義一些能變量,可以在app直接使用
preBootstrapCustomizations: ./src/theme/variables.scss
src/theme/variables.scss主要是定義了一些與顏色相關(guān)的變量
// 自己定義顏色 $cyan: #33e0ff; $humility: #777; // Bootstrap 變量 $brand-primary: darken(#428bca, 6.5%); $brand-secondary: #e25139; $brand-success: #5cb85c; $brand-warning: #f0ad4e; $brand-danger: #d9534f; $brand-info: #5bc0de; $text-color: #333; $font-size-base: 14px; $font-family-sans-serif: "Helvetica Neue", Helvetica, sans-serif;
bootstrapCustomizations
自定義樣式,在preBootstrapCustomizations加載后,所有可以在其中使用preBootstrapCustomizations定義的變量
appStyles
bootstrap加載后,最后加載里面的樣式,這里可以重寫一些bootstrap樣式
appStyles: ./src/theme/bootstrap.overrides.scss
src/theme/bootstrap.overrides.scss重新定義了一些樣式
.navbar-brand {
position: relative;
padding-left: 50px;
}
.navbar-default .navbar-nav > .active > a,
.navbar-default .navbar-nav > .active > a:hover,
.navbar-default .navbar-nav > .active > a:focus {
color: #33e0ff;
background-color: transparent;
}
應(yīng)用
打開我們的scr/containers/App/App.js現(xiàn)在添加一個bootstrap樣式的導(dǎo)航條吧
這里我們添加了兩個文件App.scss(App目錄中)樣式,圖片logo.png(Home目錄中),代碼我就不貼了,CSS不是我們目的,可以自己在源碼中看,非常簡單
import React,{Component, PropTypes} from 'react'
import {IndexLink} from 'react-router' //主頁路由
import { Navbar, Nav, NavItem } from 'react-bootstrap'; // 導(dǎo)航組件
export default class App extends Component {
render(){
const styles = require('./App.scss') //scss的樣式
return(
<div className={styles.app}>
<Navbar fixedTop>
<Navbar.Header>
<Navbar.Brand> //注意這里,就用了我們重寫的navbar-brand
<IndexLink to="/" activeStyle={{color: '#33e0ff'}}>
<div className={styles.brand}/>
<span>React Redux Example</span>
</IndexLink>
</Navbar.Brand>
<Navbar.Toggle/>
</Navbar.Header>
</Navbar>
<div className={styles.appContent}>{this.props.children}</div>
<div>App footer</div>
</div>
)
}
}
最終效果如圖

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
React實(shí)現(xiàn)antdM的級聯(lián)菜單實(shí)例
這篇文章主要為大家介紹了React實(shí)現(xiàn)antdM的級聯(lián)菜單實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
React中映射一個嵌套數(shù)組實(shí)現(xiàn)demo
這篇文章主要為大家介紹了React中映射一個嵌套數(shù)組實(shí)現(xiàn)demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
react中hooks使用useState的更新不觸發(fā)dom更新問題及解決
這篇文章主要介紹了react中hooks使用useState的更新不觸發(fā)dom更新問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01
react PropTypes校驗(yàn)傳遞的值操作示例
這篇文章主要介紹了react PropTypes校驗(yàn)傳遞的值操作,結(jié)合實(shí)例形式分析了react PropTypes針對傳遞的值進(jìn)行校驗(yàn)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2020-04-04
在React中使用React.createRef:更優(yōu)雅的DOM引用方式
React提供了多種方式來引用DOM元素,其中React.createRef()是一種更為現(xiàn)代、更優(yōu)雅的方式,在這篇文章中,我們將深入了解React.createRef()的應(yīng)用,以及它為開發(fā)者帶來的便利,感興趣的朋友一起看看吧2024-01-01
使用webpack配置react-hot-loader熱加載局部更新
這篇文章主要介紹了使用webpack配置react-hot-loader熱加載局部更新,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01

