作者:Creative Tim

  译者:Echa 攻城狮

如何在React中使用Bootstrap?20240823更新

  转发链接:https://www.creative-tim.com/blog/web-design/how-to-use-bootstrap-with-reactjs/

  毫无疑问,构建强大的Web应用程序时,Bootstrap和ReactJS仍然是最受欢迎的选择。在ReactJS中使用本机Bootstrap并不像看起来那样容易。但是,可以使用不同的方法。

  React是一个简单的库,用于创建交互式前端网页,其基于组件的体系结构可以嵌套或并排放置。因此,将第三方库添加到React很容易。

  但是,Bootstrap在很大程度上依靠jQuery来为其用户界面组件提供动力。由于jQuery直接操作文档对象模型(DOM),因此Bootstrap与React固有的声明方法相矛盾。如果您希望包含一个带有响应式12列网格的香草Bootstrap样式表或不涉及jQuery的组件,则可以轻松地将这些组件添加到React中。但是,不能以这种方式集成依赖jQuery的组件。

  因此,要将Bootstrap与ReactJS一起使用,必须有一种方法来删除Bootstrap的jQuery依赖关系。

  将Bootstrap与ReactJS一起使用的第一个选择是将原始CSS Bootstrap文件包含在ReactJS中。

  1.使用以下命令在您的系统中创建一个新的默认Create React App项目:

  npx create-react-app my-project

  上面的命令使用基本模板创建项目。要使用其他可用模板创建项目,请执行以下命令:

  npx create-react-app my-project–template [template-name]

  您可以通过在npm上搜索“ cra-template- *”来找到可用模板的列表。模板通常以“ cra-template- [template-name]”格式命名。只需在上面的命令中输入所需的模板名称即可。

  2.使用以下命令运行新项目

  使用以下命令导航到新项目:

  cd my-project

  使用以下命令启动npm:

  npm start

  3.将Bootstrap样式表链接到ReactJS。

  使用以下命令安装Bootstrap:

  npm install bootstrap

  在create-react-app软件包的src / index.js或App.js文件中 包含以下代码:

  导入“ bootstrap / dist / bootstrap.min.css”;

  现在,您可以在Bootstrap样式表成功集成到React应用程序后,将Bootstrap类与ReactJS代码一起使用。

  为了最好地使用ReactJS,将Bootstrap类作为React组件导入将是理想的。幸运的是,这是通过利用第三方库(如react-bootstrap和reactstrap)来完成的。

  的反应的自举库是替换引导JavaScript和已经从头开始建立为一个真正阵营成分,通过除去jQuery的依赖关系最常用的库之一。该库的最新版本仅支持Bootstrap v4。

  安装react-bootstrap库

  要使用该库,可以使用以下命令进行安装:

  npm install react-bootstrap引导程序

  使用react-bootstrap的组件

  要使用这些组件,只需导入单个组件(例如react-bootstrap / Button)而不是整个库。这样可以确保仅提取您使用的组件,从而减少了发送给客户端的代码。

  从“ react-bootstrap / Button”导入Button;

  可用的组件包括警报,手风琴,徽章,面包屑,按钮,按钮组,卡片,轮播,下拉菜单,表单,输入组,图像,图形,巨型机,列表组,模式,导航,导航栏,覆盖图,分页,弹出窗口,进度,微调框,表格,表格,工具提示和图示。

  导入样式表

  尽管react-bootstrap不一定依赖于Bootstrap的非常精确的版本,但仍需要某些样式表才能使用这些组件。运行以下命令:

  npm安装引导程序

  现在,您可以在src / index.js或App.js文件中包含以下代码:

  导入“ bootstrap / dist / css / bootstrap.min.css”;

  萨斯

  如果使用的是Sass,请确保安装了node-sass软件包。然后,您可以在主Sass文件中包含Bootstrap的源Sass文件。这适用于典型的create-react-app应用程序。在您的src / App.scss文件中包含以下代码。

  导入“〜bootstrap / scss / bootstrap”;

  该reactstrap库已明确被用于引导V4使用创建的,它可以让你相关的引导组件导入到你的ReactJS项目。

  安装reactstrap库

  要使用该库,可以使用以下命令进行安装:

  npm install reactstrap react react-dom

  使用reactstrap的组件

  要使用相关的组件,您可以简单地导入所需的组件而不是整个库。这样可以确保仅提取您使用的组件,从而减少了发送给客户端的代码。例如:

  import { Button } from ‘reactstrap’;

  可用的组件包括警报,徽章,面包屑,按钮下拉菜单,按钮组,按钮,卡片,轮播,折叠,下拉菜单,淡入淡出,表单,输入组,巨型机,布局,列表组,媒体,模式,导航栏,导航,分页,弹出窗口,进度,微调框,表格,标签,祝酒词和工具提示。

  导入样式表

  为了使您按预期工作,您需要手动添加Bootstrap CSS。运行以下命令:

  npm安装引导程序

  并且,通过包含以下代码,将Bootstrap CSS导入到reactstrap的src / index.js文件中:

  导入“ bootstrap / dist / css / bootstrap.css”;

  react-bootstrap和reactstrap还有其他选项,可用于有效地将新的Bootstrap之类的组件用于ReactJS。例子包括react-bootstrap-table2之类的东西,react-bootstrap-table的重建。

  顾名思义,react-bootstrap-table2显式用于创建Web应用程序的动态表。由于名称已经在npm上使用,因此此模块的安装需要运行以下命令:

  npm install react-bootstrap-table-next

  安装后,需要在使用模块之前将react-bootstrap-table2 CSS添加到应用程序中。在使用该模块之前,请添加以下代码:

  导入“ react-bootstrap-table-next / dist / react-bootstrap-table2.min.css”;

  用于在Bootstrap中包含Bootstrap的选项取决于您使用的Bootstrap版本,所需组件的类型以及所需的灵活性。

  《React 中请求远程数据的四种方法 》

  《在React中实现和Vue一样舒适的keep-alive 》

  《我读完了React的API,并为新手送上了一些建议 》

  《基于 React 打造高自由度的 IDE 布局系统》

  《推荐18个最佳React.js项目示例「值得收藏」》

  《React.js 项目实践——创建个人作品集网页》

  《细聊 React 是如何创建 vdom 和 fiber tree「实践」》

  《深入浅出 React V16.4 生命周期的来龙去脉》

  《在 React 中进行事件驱动的状态管理「实践」》

  《一文带你搞懂React-native源码解析》

  《常见的8个问题带你进阶 React》

  《分析 React 组件的渲染性能「实践」》

  《实践React Router v5:完整指南》

  《前端必备的20种基本React工具「干货」》

  《8个顶级React.js免费模板》

  《推荐36种免费React模板和主题「干货」》

  《「笔记」React Hooks 深入细品系列》

  《这就是你日思夜想的 React 原生动态加载「值得收藏」》

  《「干货满满」React Hooks 最佳实践》

  《手把手教你如何实现一个React水印组件「实践」》

  《「实践」React 中必会的 10 个概念》

  《「干货」深入浅出React组件逻辑复用的那些事儿》

  《手把手教你从Mixin深入到HOC再到Hook【React】》

  《深入Facebook 官方React 状态管理器Recoil讲解》

  《手把手教你实践搭建React组件库「超详细」》

  《在 React 中自动复制文本到剪贴板「实践」》

  《「干货满满」从零实现 react-redux》

  《深入详解大佬用33行代码实现了React》

  《让你的 React 组件性能跑得再快一点「实践」》

  《React源码分析与实现(三):实践 DOM Diff》

  《React源码分析与实现(一):组件的初始化与渲染「实践篇」》

  《React源码分析与实现(二):状态、属性更新->setState「实践篇」》

  《细说React 核心设计中的闪光点》

  《手把手教你10个案例理解React hooks的渲染逻辑「实践」》

  《React-Redux 100行代码简易版探究原理》

  《手把手深入教你5个技巧编写更好的React代码【实践】》

  《React 函数式组件性能优化知识点指南汇总》

  《13个精选的React JS框架》

  《深入浅出画图讲解React Diff原理【实践】》

  《【React深入】React事件机制》

  《Vue 3.0 Beta 和React 开发者分别杠上了》

  《手把手深入Redux react-redux中间件设计及原理(上)【实践】》

  《手把手深入Redux react-redux中间件设计及原理(下)【实践】》

  《前端框架用vue还是react?清晰对比两者差异》

  《为了学好 React Hooks, 我解析了 Vue Composition API》

  《【React 高级进阶】探索 store 设计、从零实现 react-redux》

  《写React Hooks前必读》

  《深入浅出掌握React 与 React Native这两个框架》

  《可靠React组件设计的7个准则之SRP》

  《React Router v6 新特性及迁移指南》

  《用React Hooks做一个搜索栏》

  《你需要的 React + TypeScript 50 条规范和经验》

  《手把手教你绕开React useEffect的陷阱》

  《浅析 React / Vue 跨端渲染原理与实现》

  《React 开发必须知道的 34 个技巧【近1W字】》

  《三张图详细解说React组件的生命周期》

  《手把手教你深入浅出实现Vue3 & React Hooks新UI Modal弹窗》

  《手把手教你搭建一个React TS 项目模板》

  《全平台(Vue/React/微信小程序)任意角度旋图片裁剪组件》

  《40行代码把Vue3的响应式集成进React做状态管理》

  《手把手教你深入浅出React 迷惑的问题点【完整版】》

  作者:Creative Tim

  译者:Echa 攻城狮

  转发链接:https://www.creative-tim.com/blog/web-design/how-to-use-bootstrap-with-reactjs/