国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

React應用中使用Bootstrap的方法

2019-11-19 15:48:02
字體:
來源:轉載
供稿:網友

前言

本節我們將把bootstrap,font-awesome應用到app中,同時創建一個基本的主頁。主要將用到以下包:

  • bootstrap-loader及配合工作的一系列loader: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') ]

然后在應用目錄下添加.bootstraprc配置文件,對要用到的組件進行選擇,怎么配置在官方文檔中有非常詳細的配置說明及模板。可以直接使用。

然后在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相關的文件

preBootstrapCustomizations

定義一些能變量,可以在app直接使用

preBootstrapCustomizations: ./src/theme/variables.scss

src/theme/variables.scss主要是定義了一些與顏色相關的變量

// 自己定義顏色$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;}

應用

打開我們的scr/containers/App/App.js現在添加一個bootstrap樣式的導航條吧

這里我們添加了兩個文件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'; // 導航組件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>  ) }}

最終效果如圖

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 贵州省| 长沙市| 油尖旺区| 丽水市| 浙江省| 项城市| 丹棱县| 轮台县| 普定县| 双鸭山市| 运城市| 南澳县| 屏东县| 桦甸市| 赞皇县| 封开县| 曲阳县| 上虞市| 正安县| 永兴县| 梧州市| 北流市| 舒兰市| 酒泉市| 嵩明县| 通城县| 额尔古纳市| 饶平县| 磐安县| 林芝县| 舞阳县| 平利县| 吉安县| 武汉市| 娱乐| 东城区| 冕宁县| 永兴县| 壶关县| 且末县| 监利县|