当前位置:首页 > 日记 > 正文

React应用中使用Bootstrap的方法

React应用中使用Bootstrap的方法

前言

本节我们将把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目录中)样式,图片lo.webp(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>  ) }}

最终效果如图

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

相关文章

HTTP 错误 404 - 文件或目录未找到

HTTP 错误 404 - 文件或目录未找到

错误,文件,未找到,目录,电脑软件,MIME设置问题导致某些类型文件无法下载(以ISO为例) 症状举例: HTTP 错误 404 - 文件或目录未找到。 原因分析: IIS6.0取消了对某些MIME类型的支持,例如ISO,致使客户端下载出错。 解决方法: 在IIS中 属…

HTTP 错误 500.19- Internal Serve

HTTP 错误 500.19- Internal Serve

错误,解决方法,电脑软件,HTTP,Error,HTTP 错误 500.19- Internal Server Error 错误解决方法,碰到这个问题的原因有很多,大家可以参考下,看属于哪种情况。刚在本机部署了一个WebService测试,浏览的时候出现了&ldquo;HTTP 错误 500.19 - Intern…

PHP使用数组依次替换字符串中匹配

PHP使用数组依次替换字符串中匹配

替换字符串,数组,电脑软件,PHP,先来看个sql语句:select * from table where ctime >= '[date-14]' and ctime <= '[date-1]';想把上面这句sql的中括号表示的日期依次换成下面的数组中的元素array('2015-07-01','2015-07-15');用正则…

php指定长度分割字符串str_split函

php指定长度分割字符串str_split函

函数用法,分割字符串,示例,长度,电脑软件,本文实例讲述了php指定长度分割字符串str_split函数用法。分享给大家供大家参考,具体如下:示例1:$str = 'abcdefgh';$arr = str_split($str,2);运行结果如下:array(4) { [0]=> string(2) "ab" [1]=…

IF函数的使用方法 | 入门+进阶+高

IF函数的使用方法 | 入门+进阶+高

函数,进阶,使用方法,入门,高级,IF函数是工作中最常用的函数之一,所以兰色今天决定用一篇文章把IF函数的使用方法再梳理一番。看过你会不由感叹:原来IF函数也可以玩的这么高深!!一、IF函数的使用方法(入门级)1、单条件判断返回值=IF(A1>20,"…

单引号怎么打(‘ ’)

单引号怎么打(‘ ’)

单引号,电脑软件,下面是小编整理的单引号怎么打的详细教程,如果有更好的方法欢迎补充:1.在英文状态下键盘上输入既可以得到。&lsquo; &rsquo;(键位由于每个键盘不一样,大体在回车键附近或冒号分号键右边)注意:打出来的单引号和平时的不一样,是那…

php实现的双色球算法示例

php实现的双色球算法示例

算法示例,双色球,电脑软件,php,本文实例讲述了php实现的双色球算法。分享给大家供大家参考,具体如下:<?phpfunction DoubleBall(){ $sysBlueball = mt_rand(1,16); $sysRedball = array(1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,2…

在win7下装win10双系统详细图文安

在win7下装win10双系统详细图文安

安装教程,双系统,图文,详细,电脑软件,  win10系统推出已经有一段时间了,不少人想要体验一下最新的系统,但又舍不得好用的win7系统。这个时候,装双系统就是最好的选择。我们可以使用小白一键重装,在win7下装win10双系统,过程简单,方便快捷。第一…

Word2013插入艺术字效果的两种方法

Word2013插入艺术字效果的两种方法

方法,效果,艺术字,两种,电脑软件,  Word2013发行后,操作界面简洁而亮丽,操作系统也简便了不少,但和以往操作有所区别,那么下面就由小编为您分享下插入艺术字效果的技巧,希望能帮助您,有需要的朋友可以来看看哦。Word2013插入艺术字效果方法一步…

Web服务器访问失败故障处理技巧

Web服务器访问失败故障处理技巧

服务器,故障处理,技巧,电脑软件,Web,很多公司都架设了Web服务器,不过架设好的Web服务器如果不经过访问测试,很可能无法达到顺利发布信息的目的;这不,本文下面推荐的一则Web服务器访问失败故障就比较常见,现在我们就对它的排除过程进行总结,希望日…

PHP实现找出数组中出现次数超过数

PHP实现找出数组中出现次数超过数

数字,算法示例,数组,组中,长度,本文实例讲述了PHP实现找出数组中出现次数超过数组长度一半的数字算法。分享给大家供大家参考,具体如下:<?php* 算法要求:数组中有一个数字出现的次数超过了数组长度的一半,找出这个数字。** 算法分析:我们需要…

结合mint-ui移动端下拉加载实践方

结合mint-ui移动端下拉加载实践方

下拉加载,方法,移动端,电脑软件,mint,1.npm i mint-ui -S2.main.js中引入import 'mint-ui/lib/style.css'3.以下是代码结构部分:<template> <div class="main-body" :style="{'-webkit-overflow-scrolling': scrollMode}"> <v-loadm…