我后悔没有在自己成为 React 开发者之前做的 6 件事情

PassionPenguin @ 绿色有机无公害

由 Francisco Gonzalez 上传至 Unsplash

React 是一个很好的适合我们去学习的工具,它让我们能够以我们自己的方法编写代码完成任务。但即使它的功能很强大,它也有着不少的限制。

对于新的开发者而言,其实并没有明确的指南告诉我们,某一个场景最适合用哪一个工具。这让每一个问题都有各种各样的解决方案,而我也同样掉到了这个坑里面,并且已经无力回天,没法去采用一些别的最佳实践了。

今天我将要分享我最应该在我的 React 开发旅程前期就应该开始做的 6 件事。

1. 测试

长期以来,测试是我的弱项。我并没有为 React 组件编写测试样例,并且正如预期的那样,我经常因为某些输入错误而不得不进行调试。

但即便测试这个词语看起来很吓人,在 React 中进行测试真的是很简单的一件事情(对于大多数情况而言)。

写一个简单的测试只需要花费两分钟,但这可能会为我们在未来节省大量的时间。下面就是一个测试 Title 组件渲染是否可以正确渲染的例子:

it('checks if the title component is in the document', () => {
    expect(screen.getByText('Title')).toBeInTheDocument()
})
复制代码

而如果你使用的是 create-react-app 命令创建你的 React 应用程序,那么命令本身已经正确地为你设置好了测试套件,只需要尽早地开始编写测试代码即可。

2. 使用正确的文件夹结构

我认为当我还是一个 React 的新手时,我犯下的最大错误就是没有使用正确的文件夹结构。我基本上将文件按照他们的类别分类:

|-store
  |--actions
    |---UserAction.js
    |---ProductAction.js
    |---OrderAction.js
  |--reducers
    |---UserReducer.js
    |---ProductReducer.js
    |---OrderReducer.js
复制代码

但当项目逐步变大以后,我发现查找文件变得困难了许多。

因此我最终还是开始按照文件的特征去排序整理,意味着所有类似的文件将放在一个同样的文件夹下面,例如:

|-store
  |--user
    |---UserAction.js
    |---UserReducer.js
  |--product    
    |---ProductAction.js
    |---ProductReducer.js
  |--order    
    |---OrderAction.js
    |---OrderReducer.js
复制代码

现在对我而言在文件系统中导航到我想要查看的文件变得简单了许多!

3. 使用样式化的组件

我一开始使用 css 文件去给我的组件添加样式,但是随着时间的推进以及项目的扩大,这真的变得越发混乱。

在一段时间以后我了解并学习了 sass,而它真是棒极了!不过即使它在原 css 上提供了些语法糖,但给我的组件加样式还是真的困难,尤其是在重复使用某些样式的时候 —— 我总是会忘记我已经编写了这一种样式在我的样式表中了。

// jsx 中
<button className="btn-submit">

<button/>


// inside css files
.btn-submit {

}
复制代码

同样,个人而言,我并不喜欢 JSXclassName 属性。

过了一段时间我发现了一个可以拯救我的叫做 styled-components 的库。现在我仅仅需要对不同的组件定义我的样式,而我的代码也变得干净了许多,阅读起来也舒服、轻松了许多。

同样的,这个组件也支持 props 属性,帮助我大量地减少了特定条件下的特殊样式。

const Button = styled.button`
  font-size: 1em;
  margin: 1em;
  padding: 0.25em 1em;
  border-radius: 3px;
`;
复制代码

4. 尽早转向使用函数组件

一开始,我是通过 class-components 学习的 React。在那一年左右,我使用了类组件。

当我转向使用函数组件后,我发现了它们巨大的优点。我想 react-hooks 是自 React 出现以来的最好的东西。

但现在几乎没有任何原因让人们尝试使用基于类的组件。

而现在,我正尝试着将所有组件重写为函数组件。

译者注:React 的函数组件是 React 组件的另一种定义方式,两种方式都可以用于定义组件,但是相比于类组件,函数组件要更简单好用些,它会直接返回一个元素,如果希望了解更多内容,请直接搜索 函数组件

const Hello = () => {
    return <div>Hello Word</div>
}
复制代码

5. 使用表单处理库

处理表单可能是任何应用程序中最常见的功能之一,但我在原生的 onChange 方法上花了很多时间尝试去使用它来完成表单处理的时候,我才发现,使用这个功能处理数据和验证真的非常痛苦!

直到我发现了 Formikreact-hook-form

使用这两个库能让表单处理变得更加容易和简洁。最重要的是,目前对我来说,表单验证是可以通过简单的一两句声明,就可以完成的,真的变得极度容易。

6.使用 Linter 和 Formatter

长时间以来,手动格式化我的代码是一件很麻烦的事情。我喜欢我的代码整洁干净,因此每次需要:

  • 删除未使用的变量
  • 删除未使用的 function
  • 删除未使用的 import
  • 使用适当的缩进

而在遇到 EslintPrettier 之前,我不得不手动完成这些。而这两个库能让痛苦的格式化工作变得容易许多!

因此,这些是我希望在职业生涯早期开始使用的前 6 个库,你的想法是什么呢?

感谢阅读,祝你有个明媚的好日子嗷!

如果发现译文存在错误或其他需要改进的地方,欢迎到 掘金翻译计划 对译文进行修改并 PR,也可获得相应奖励积分。文章开头的 本文永久链接 即为本文在 GitHub 上的 MarkDown 链接。


掘金翻译计划 是一个翻译优质互联网技术文章的社区,文章来源为 掘金 上的英文分享文章。内容覆盖 AndroidiOS前端后端区块链产品设计人工智能等领域,想要查看更多优质译文请持续关注 掘金翻译计划官方微博知乎专栏

文章分类
前端