最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 我后悔没有在自己成为 React 开发者之前做的 6 件事情

    正文概述 掘金(PassionPenguin)   2021-02-28   400

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

    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 上提供了些语法糖,但给我的组件加样式还是真的困难,尤其是在重复使用某些样式的时候 —— 我总是会忘记我已经编写了这一种样式在我的样式表中了。

    // inside 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 出现以来的最好的东西。

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

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

    5. 使用表单处理库

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

    直到我发现了 Formikreact-hook-form

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

    6.使用 Linter 和 Formatter

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

    • 删除未使用的变量
    • 删除未使用的功能
    • 删除未使用的进口
    • 使用适当的缩进

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

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

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



    起源地下载网 » 我后悔没有在自己成为 React 开发者之前做的 6 件事情

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元