React开发工具有哪些

本篇内容主要讲解“React开发工具有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“React开发工具有哪些”吧!

1. Webpack Bundle Analyzer

有没有想过你的应用程序中的哪些软件包或部分占据了所有空间?好了,你可以使用Webpack Bundle  Analyzer进行查找,该软件包将帮助你确定占用最大空间的输出文件。

它将创建一个实时服务器,并向你提供一个交互式的、显示包内容的树形图。有了这个工具,你就可以看到渲染的文件的位置、它们的gzip大小、解析后的大小以及它们的父/子文件。

你可以根据你所看到的优化你的React应用!这是它的屏幕截图:

React开发工具有哪些

从上图中我们可以清楚地看到pdf软件包在应用程序中占据了最大的空间,但这也占用了屏幕上的最大空间。这非常有用。

不过,截图是最小的,你还可以通过有用的选项来查看它的更多细节,比如 generateStatsFile:  true,还可以选择生成一个静态的HTML文件,保存在开发环境以外的地方,供以后使用。

2. React-Proto

React-Proto是面向开发人员和设计人员的原型制作工具。它是桌面软件,因此你必须先下载并安装该软件然后再使用。

这是此软件正在使用的示例:

React开发工具有哪些

该应用程序可以让你声明props及其类型,在树状图中查看你的组件,导入背景图片,定义它们为有状态或无状态,定义它们的父组件是什么,放大/缩小,并将你的原型导出到一个新的或现有的项目中。

该App似乎更适合Mac用户,但对于Windows用户仍然可以正常使用。

完成用户界面的映射后,你可以选择导出到现有项目或新项目。如果选择导出到现有项目并选择根目录,它将把它们导出到  ./src/components,如下所示:

React开发工具有哪些

这是我们在例子中用到的一个组件的例子:

React开发工具有哪些

React-Proto在GitHub上获得了2,000颗星。

不过,就我个人而言,我认为这个应用需要更新,需要更多的工作,尤其是随着React Hooks的发布。

3. Why Did You Render

Why Did You Render 可以让 React 通知你可避免的重新渲染。

这非常有用,不仅可以指导你进行项目的性能修复,还可以帮助你了解React的工作方式。而且,当你对React的工作原理有了更好的了解时,它将使你成为一个更好的React开发人员。

你可以通过声明一个额外的静态属性 whyDidYouRender 并将其值为 true 来将侦听器附加到任何自定义组件:

import React from 'react' import Button from '@material-ui/core/Button'  const Child = (props) => <div {...props} />  const Child2 = ({ children, ...props }) => (   <div {...props}>     {children} <Child />   </div> )  Child2.whyDidYouRender = true  const App = () => {   const [state, setState] = React.useState({})    return (     <div>       <Child>{JSON.stringify(state, null, 2)}</Child>       <div>         <Button type="button" onClick={() => setState({ hello: 'hi' })}>           Submit         </Button>       </div>       <Child2>Child #2</Child2>     </div>   ) }  export default App

这样做之后,你的控制台才会发出令人难以置信的令人讨厌的警告:

React开发工具有哪些

不要误解,把它当作一件好事。充分利用那些烦人的消息,这样你就可以修复那些浪费的重新渲染,那些烦人的消息最终会离你而去!

4. Create React App

大家都知道,Create React App 是开始开发React项目的最快方法(开箱即用,具有现代功能)。

有什么比 npx create-react-app容易?

我们中有些人可能不知道的是如何使用CRA创建TypeScript项目,你要做的就是在末尾添加 –typescript:

npx create-react-app <name> --typescript

这样可以省去手动将TypeScript添加到CRA项目中的麻烦。

5. React Lifecycle Visualizer

React Lifecycle Visualizer 是一个npm软件包,用于跟踪和可视化任意React组件的生命周期方法。

与 Why Did You Render 一样,你可以启用你选择的任何组件以带出生命周期可视化器:

import React from 'react' import {   Log,   VisualizerProvider,   traceLifecycle, } from 'react-lifecycle-visualizer'  class TracedComponent extends React.Component {   state = {     loaded: false,   }    componentDidMount() {     this.props.onMount()   }    render() {     return <h3>Traced Component</h3>   } }  const EnhancedTracedComponent = traceLifecycle(TracedComponent)  const App = () => (   <VisualizerProvider>     <EnhancedTracedComponent />     <Log />   </VisualizerProvider> )

这将显示可视化器,如下所示:

React开发工具有哪些

https://github.com/Oblosys/react-lifecycle-visualizer

但是,这样做的缺点是,它目前仅适用于类组件,因此尚不支持Hooks。

6. Guppy

Guppy是React的好朋友,免费的应用程序管理器和任务运行器,它在桌面上运行。

他们似乎会优先考虑那些在React中进行开发的新手。不过,这可能对高级开发人员也有帮助。

它为React开发人员经常面对的许多典型任务提供了友好的图形用户界面,例如创建新项目,执行任务和管理依赖项。

Windows支持已于2018年8月添加,因此你可以放心,它是跨平台的。

这是Guppy的样子:

React开发工具有哪些

https://github.com/joshwcomeau/guppy

7. react-testing-library

我一直都很喜欢react-testing-library,因为在编写单元测试时感觉不错。这个包提供了React  DOM测试实用程序,可以鼓励良好的测试实践。

该解决方案旨在解决测试你的实现细节的问题,而不是像用户看到的那样测试React组件的输入/输出。

测试实现细节并不是确保应用程序按预期工作的有效方法。

当然,你会对你的组件所需要的数据的获取方式、使用哪种排序方式等等,都会更有信心。但是,如果必须更改实现的方式以指向另一个数据库,则单元测试将失败,因为它们是耦合逻辑的实现细节。

这是react-test -library解决的一个问题,因为在理想的情况下,你只希望你的用户界面能够正常工作,并且最终能够正确地呈现出来。

只要这些组件仍能提供预期的输出,如何将数据获取到这些组件并不重要。

以下是使用此库如何放置测试的示例代码:

// 提升辅助函数(但不是vars)以在测试用例之间重用 const renderComponent = ({ count }) =>   render(     <StateMock state={{ count }}>       <StatefulCounter />     </StateMock>,   )  it('renders initial count', async () => {   // 在每次测试中渲染新的实例,以防止泄漏状态。   const { getByText } = renderComponent({ count: 5 })    await waitForElement(() => getByText(/clicked 5 times/i)) })  it('increments count', async () => {   // 在每次测试中渲染新的实例,以防止泄漏状态。   const { getByText } = renderComponent({ count: 5 })    fireEvent.click(getByText('+1'))   await waitForElement(() => getByText(/clicked 6 times/i)) })

8. React Developer Tools

React Developer Tools是一个扩展,可以检查Chrome和Firefox Developer  Tools中React的组件层次结构。

这是该列表中最广为人知的扩展,并且仍然是React开发人员可以用来调试其应用程序的最有用的工具之一。

9. Bit

Bit是使用组件库(例如Material-UI或Semantic UI React)的一个很好的选择。

利用Bit,你可以探索数千个开源组件,并可以使用它们来构建项目。

React开发工具有哪些

https://bit.dev/

有许多不同的React组件供任何人使用,包括标签、按钮、图表、表格、导航栏、下拉菜单、加载旋转器、日期选择器、面包屑、图标、布局等。

这些都是由其他React开发人员上传的,就像你和我一样。

但是,还有一些有用的实用程序,例如格式化日期。

10. Storybook

如果你还不了解Storybook,我强烈建议你开始使用它,如果你想更轻松的体验构建UI组件,那么你可以开始使用它。

该工具启动了具有即时支持的热重载功能的实时开发服务器,你可以在其中独立地实时开发React组件。

这其中的另一个好处是,你可以使用目前已有的开源插件,将你的开发体验提升到一个全新的高度。

例如,使用Storybook README包,你可以在开发React组件的同时创建README文档,以便在同一页面上直接用于生产。

这足以用作常规文档页面:

React开发工具有哪些

11. React Sight

React Sight通过向你展示整个应用程序的实时组件层次结构树,使你可视化React应用程序。

它还支持react-router,Redux和React Fiber。

使用此工具,你可以将鼠标悬停在节点上,这些节点是指向树中与它们直接相关的组件的链接。

如果你无法查看结果,则可能需要在地址栏中输入chrome:extensions,找到“ React  Sight”框,然后单击“允许访问文件URL”开关。

12. React Cosmos

React Cosmos是用于创建可重复使用的React组件的开发工具。

它会扫描项目中的组件,并使你能够:

  • 使用props,context和state的任意组合渲染组件。

  • 模拟每个外部依赖项(例如API响应,localStorage等)。

  • 与正在运行的实例进行交互时,查看应用程序状态的实时变化。

13. CodeSandbox

这无疑是最好的工具之一,让你的手比眨眼的速度更快(好吧,也许不是那么快)。

这个称为CodeSandbox的工具是一个在线编辑器,可以让你创建从原型到部署的Web应用程序&mdash;&mdash;全部从网站上完成!

CodeSandbox最初仅在较早的阶段支持React,但现在已扩展到适用于Vue和Angular等库的其他入门模板。

他们还支持通过使用常见的静态站点生成器(例如Gatsby或Next.js)创建项目来启动下一个React Web项目。

关于CodeSandbox,有很多很棒的事情要谈论。首先,它非常活跃。

如果你需要探索一些别人正在建设的项目,为了方便你,点击探索(explore),可以很容易地获得一堆代码示例,帮助你翻新下一个项目。

React开发工具有哪些

开始编辑项目后,你将开始意识到要使用的实际上是功能强大的VS Code编辑器。

14. React Bits

React Bits 是一个 React  模式、技术、技巧和窍门的集合,所有这些都是以类似于在线文档的形式写成的,在这里你可以快速访问不同的设计模式和技术、反模式、风格设计、用户体验变化,以及其他有用的  React 相关材料,所有这些都在同一个标签页上。

他们有一个GitHub仓库,目前有9923星。

一些示例包括诸如prop代理,在不同场景下处理各种UX的组合之类的概念,甚至还揭示了每个React开发人员都应注意的一些陷阱。

这就是他们页面上的样子。正如你在左侧的侧菜单中所看到的,有很多信息:

React开发工具有哪些

15. folderize

folderize是一个不到7天前发布的VS  Code扩展。它使你可以将组件文件转换为组件文件夹结构,你的React组件仍然是一个组件,它现在只是转换成了一个目录。

例如,假设你正在创建一个React组件,该组件将文件作为显示有用信息(如其元数据)的props。

元数据组件的逻辑占用了很多行,所以你决定把这个拆成一个单独的文件。但是,当你决定这样做时,现在你有了两个相互关联的文件。

因此,如果你的目录如下所示:

React开发工具有哪些

你可能想要像 Apples一样将 FileView.js 和 FileMetadata.js 抽象到目录结构中,尤其是在考虑添加更多与  FileScanner.js 之类的文件相关的组件时。

这就是folderize为你所做的,以便它们可以具有类似于以下的结构:

React开发工具有哪些

16. React Starter Projects

这是一个很棒的React启动程序项目列表,你可以在一个页面上全部查看。所以,如果你是那种觉得同时面对一大堆选项很有用的人,那么这个就是适合你的。

一旦你看到一个你喜欢的入门项目,你就可以简单地克隆这个资源库,并为你即将到来的应用做你自己的修改。

但是,并不是所有的都要通过克隆资源库来使用,因为其中有些是要安装的,这就成了你的项目的依赖。

这样可以更轻松地获取更新并保持项目整洁。

页面样子如下:

React开发工具有哪些

17. Highlight Updates

这可以说是任何人在开发工具箱中最重要的工具。Highlight Updates是React  DevTools扩展的一个功能,它可以让你看到你的页面中哪些组件在不必要地重新渲染。

React开发工具有哪些

它可以帮助你在开发页面时发现瓶颈,并使其更容易,因为它们会将严重的重新呈现问题着色为橙色或红色。

除非你的目标是构建一个平庸的应用程序,否则为什么不希望这个美丽的东西站在你的身边?

18. React Diff Viewer

React Diff  Viewer是使用Diff和React制作的简单美观的文本diff查看器。这支持诸如拆分视图,内联视图,单词差异,行高亮显示等功能。

如果你试图将此功能嵌入到您的笔记(如Boostnote)中,并对其进行定制,使其更适合你的应用程序(主题颜色、文档与故事书演示的组合,等等),那么这将非常有用。

React开发工具有哪些

19. JS.coach

我最常用于查找与React相关的资料的站点是JS.coach。它快速,简单,不断更新,并且始终为我提供所有项目所需的结果。

他们最近添加了React VR标签,这很棒!

React开发工具有哪些

20. Awesome React

GitHub Awesome React开源库列出了一系列与React相关的精彩内容。

我可能会忘记其他网站,而仅从此链接学习React。你会发现大量有用的资源,这些资源肯定会帮助你构建出色的React应用!

21. Proton Native

Proton Native提供了一个React环境来构建跨平台的本地桌面应用程序。

它是Electron的替代产品,并具有一些简洁的功能,包括:

  • 与React Native的语法相同。

  • 与现有的React库一起使用,例如Redux。

  • 跨平台。

  • 原生组件。Electron没有。

  • 兼容所有正常的Node.js包。

有兴趣了解更多吗?阅读他们的文档。

22. Devhints React.js Cheatsheet

一个很好的React备忘单,尽管它缺少React Hooks。

到此,相信大家对“React开发工具有哪些”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

原创文章,作者:carmelaweatherly,如若转载,请注明出处:https://blog.ytso.com/tech/dev/208679.html

(0)
上一篇 2021年12月7日 15:34
下一篇 2021年12月7日 15:34

相关推荐

发表回复

登录后才能评论