百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

如何在ReactJS中使用Bootstrap?

liuian 2024-12-11 15:44 26 浏览

作者:Creative Tim

译者:Echa 攻城狮

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

前言

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

为什么将Bootstrap组件包含在React中具有挑战性?

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

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

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

如何在ReactJS中使用Bootstrap?

选项1:将原始CSS Bootstrap文件包含到ReactJS中

将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.jsApp.js文件中 包含以下代码:

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

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

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

选项2:使用react-bootstrap库

反应的自举库是替换引导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.jsApp.js文件中包含以下代码:

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

萨斯

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

导入“?bootstrap / scss / bootstrap”;

选项3:使用reactstrap库

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”;

选项4:其他第三方模块

react-bootstrapreactstrap还有其他选项,可用于有效地将新的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 中请求远程数据的四种方法

在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/

相关推荐

GCI: Another key public good for international community

MembersofadelegationofhighschoolstudentsfromtheU.S.stateofWashingtonposeforaphotoa...

kube on kube 实现思路分享(kube-scheduler)

这里的kubeonkube,是指建立K8s元集群,纳管其他业务K8s集群,通过声明式API管理集群的创建、增删节点等。参考https://github.com/kubean-i...

China and India hold the key to a more inclusive global future

ByMayaMajueranLead:AsChinaandIndiamark75yearsofdiplomaticties,theircooperationcouldse...

日本真子公主的婚礼又要提上日程了吗?未婚夫:债务问题已解决

日本明仁天皇将于今年3月31日退位,德仁皇太子即将成为新一任的天皇。在平成时代最后的倒计时中,明仁天皇的孙女真子公主的婚事却又一次进入了人们的视野。(viaTheTelegraph)关注日本皇室的...

kratos源码分析系列(1)(kvm源码解析与应用 pdf)

https://github.com/go-kratos/kratos是b站开源的一个微服务框架,整体来看它结合grpc生态中的grpc-gateway,以及wire依赖注入和众多常用的trace,m...

【2.C#基础】6.循环语句(c#循环语句例子)

6.循环语句当需要多次执行同一个处理时,就需要用到循环语句。一般情况下,循环的流程图如下:6.1while循环C#中的while循环语句在给定的条件为真的情况下会重复执行目标语句。格式如下:...

使用 Google Wire 在 Go 中进行依赖注入

关注点分离、松耦合系统和依赖反转原则等概念在软件工程中是众所周知的,并且在创建良好的计算机程序过程中至关重要。在本文中,我们将讨论一个同时应用了这三个原则的技术,称为依赖注入。我们将尽可能地实践,更加...

用 Golang封装你的API(golang封装dll)
用 Golang封装你的API(golang封装dll)

每日分享最新,最流行的软件开发知识与最新行业趋势,希望大家能够一键三连,多多支持,跪求关注,点赞,留言。@头条创作挑战赛本文探讨了在用Golang封装你的API的过程以及几个不同的编程步骤。我做了一个非常有限的时间来证明如何为客户正在开...

2025-05-09 20:03 liuian

Terraform 实战 | 万字长文(terrify是什么意思中文)

Terraform是什么Terraform(https://www.terraform.io/)是HashiCorp旗下的一款开源(Go语言开发)的DevOps基础架构资源管理运维工具,可...

Go 语言入门:环境安装(go语言安装 window)

一、前言这里不同于其他人的Go语言入门,环境安装我向来注重配置,比如依赖包、缓存的默认目录。因为前期不弄好,后面要整理又影响这影响那的,所以就干脆写成文章,方便后期捡起。二、安装1.安装包htt...

Go语言进阶之Go语言高性能Web框架Iris项目实战-项目结构优化EP05

前文再续,上一回我们完成了用户管理模块的CURD(增删改查)功能,功能层面,无甚大观,但有一个结构性的缺陷显而易见,那就是项目结构过度耦合,项目的耦合性(Coupling),也叫耦合度,进而言之,模块...

如何将Go项目与Docker结合实现高效部署

在现代软件开发中,使用Docker部署应用程序已经成为一种标准实践。本文将深入探讨如何将Go项目与Docker结合,实现高效、可靠的部署过程。通过详细的步骤和丰富的示例,你将能够迅速掌握这一流程。准备...

五分钟轻松熟悉一个k8s Operator应用制作

简介:operator是一种kubernetes的扩展形式,可以帮助用户以Kubernetes的声明式API风格自定义来管理应用及服务,operator已经成为分布式应用在k8s集群部...

程序员的副业秘籍!一款可以快速搭建各类系统的后台管理系统

系统简介这是一个基于Gin+Vue+ElementUI(或ArcoDesign、AntDesign)的系统快速开发平台,采用了前后端分离,旨在帮助用户快速完成各类系统的基础功能搭建。平...

使用 Go 语言开发区块链钱包的项目目录结构设计

在开发区块链钱包时,项目的目录结构应该清晰、模块化,确保代码的可维护性和扩展性。基于Go的惯例,结合区块链钱包的功能需求,以下是一个较为合理的目录结构示例:1.目录结构blockchain-wa...