5个技巧助你编写更好的React代码

  在本文中,我想分享几个技巧,这些技巧将改善你的React代码。

  1. 解构 props

  在 JS 中解构对象(尤其是 props)可以大大减少代码中的重复。看下面的例子:

  //Parent Component import React from 'react'; import CoffeeCard from './CoffeeCard'; const CafeMenu = () => { const coffeeList = [ { id: '0', name: 'Espresso', price: '2.00', size: '16' }, { id: '1', name: 'Cappuccino', price: '3.50', size: '24' }, { id: '2', name: 'Caffee Latte', price: '2.70', size: '12' } ]; return coffeeList.map(item => ( )); }; export default CafeMenu;

  CafeMenu 组件用于存储可用饮料的列表,现在我们想要创建另一个可以显示一种饮料的组件。如果不对 props 进行解构,我们的代码将像下面这样:

  //Child Component import React from 'react'; const CoffeeCard = props => { return (

{props.coffee.name}

Price: {props.coffee.price}lt;/p>

Size: {props.coffee.size} oz

); }; export default CoffeeCard;

  如你所见,它看起来并不好,每次我们需要获取某个属性时,都要重复 props.coffee,幸运的是,我们可以通过解构来简化它。

  //Child Component (after destructuring props) import React from 'react'; const CoffeeCard = props => { const { name, price, size } = props.coffee; return (

{name}

Price: {price}lt;/p>

Size: {size} oz

); }; export default CoffeeCard;

  如果我们想将大量参数传递给子组件,我们还可以直接在构造函数(或函数组件的参数)中解构 props。比如:

  //Parent Component import React from 'react'; import ContactInfo from './ContactInfo'; const UserProfile = () => { const name = 'John Locke'; const email = 'john@locke.com'; const phone = '01632 960668'; return ; }; export default UserProfile; //Child Component import React from 'react'; const ContactInfo = ({ name, email, phone }) => { return (

{name}

E-mail: {email}

Phone: {phone}

); }; export default ContactInfo;

  2. 保持导入模块的顺序

  有时(尤其是在“容器组件”中),我们需要使用许多不同的模块,并且组件导入看上去有些混乱,如:

  import { Auth } from 'aws-amplify'; import React from 'react'; import SidebarNavigation from './components/SidebarNavigation'; import { EuiPage, EuiPageBody } from '@elastic/eui'; import { keyCodes } from '@elastic/eui/lib/services'; import './index.css' import HeaderNavigation from './components/HeaderNavigation'; import Routes from './Routes';

  关于导入模块的理想顺序有很多不同的观点。我建议多参考,然后找到适合你自己的那种。

  至于我自己,我通常按类型对导入进行分组,并按字母顺序对它们进行排序(这是可选操作)。我也倾向于保持以下顺序:

  标准模块第三方模块自己代码导入(组件)特定于模块的导入(例如CSS,PNG等)仅用于测试的代码

  快速重构一下,我们的模块导入看上去舒服多了了。

  import React from 'react'; import { Auth } from 'aws-amplify'; import { EuiPage, EuiPageBody } from '@elastic/eui'; import { keyCodes } from '@elastic/eui/lib/services'; import HeaderNavigation from './components/HeaderNavigation'; import SidebarNavigation from './components/SidebarNavigation'; import Routes from './Routes'; import './index.css'

  3.使用 Fragments

  在我们的组件中,我们经常返回多个元素。一个 React 组件不能返回多个子节点,因此我们通常将它们包装在 div 中。有时,这样的解决方案会有问题。比如下面的这个例子中:

  我们要创建一个 Table 组件,其中包含一个 Columns 组件。

  import React from 'react'; import Columns from './Columns'; const Table = () => { return (

); }; export default Table;

  Columns 组件中包含一些 td 元素。由于我们无法返回多个子节点,因此需要将这些元素包装在 div 中。

  import React from 'react'; const Columns = () => { return (

Hello World

); }; export default Columns;

  然后就报错了,因为tr 标签中不能放置 div。我们可以使用 Fragment 标签来解决这个问题,如下所示:

  import React, { Fragment } from 'react'; const Columns = () => { return ( Hello World ); }; export default Columns;

  我们可以将 Fragment 视为不可见的 div。它在子组件将元素包装在标签中,将其带到父组件并消失。

  你也可以使用较短的语法,但是它不支持 key 和属性。

  import React from 'react'; const Columns = () => { return ( <> Hello World ); }; export default Columns;

  4. 使用展示组件和容器组件

  将应用程序的组件分为展示(木偶)组件和容器(智能)组件。如果你不知道这些是什么,可以下面的介绍:

  展示组件

  主要关注UI,它们负责组件的外观。数据由 props 提供,木偶组件中不应该调用API,这是智能组件的工作除了UI的依赖包,它们不需要依赖应用程序它们可能包括状态,但仅用于操纵UI本身-它们不应存储应用程序数据。

  木偶组件有:加载指示器,模态,按钮,输入。

  容器组件

  它们不关注样式,通常不包含任何样式它们用于处理数据,可以请求数据,捕获更改和传递应用程序数据负责管理状态,重新渲染组件等等可能依赖于应用程序,调用 Redux,生命周期方法,API和库等等。

  使用展示组件和容器组件的好处

  更好的可读性更好的可重用性更容易测试

  此外,它还符合“单一责任原则” - 一个组件负责外观,另一个组件负责数据。

  示例

  让我们看一个简单的例子。这是一个 BookList 组件,该组件可从API获取图书数据并将其显示在列表中。

  import React, { useState, useEffect } from 'react'; const BookList = () => { const [books, setBooks] = useState([]); const [isLoading, setLoading] = useState(false); useEffect(() => { setLoading(true); fetch('api/books') .then(res => res.json()) .then(books => { setBooks(books); setLoading(false); }); }, []); const renderLoading = () => { return

Loading...

; }; const renderBooks = () => { return (

  • {books.map(book => (
  • {book.name}
  • ))}

); }; return <>{isLoading ? renderLoading() : renderBooks()}; }; export default BookList;

  该组件的问题在于,它负责太多事情。它获取并呈现数据。它还与一个特定的接口关联,因此在不复制代码的情况下,不能使用此组件显示特定用户的图书列表。

  现在,让我们尝试将此组件分为展示组件和容器组件。

  import React from 'react'; const BookList = ({ books, isLoading }) => { const renderLoading = () => { return

Loading...

; }; const renderBooks = () => { return (

  • {books.map(book => (
  • {book.name}
  • ))}

); }; return <>{isLoading ? renderLoading() : renderBooks()}; }; export default BookList; import React, { useState, useEffect } from 'react'; import BookList from './BookList'; const BookListContainer = () => { const [books, setBooks] = useState([]); const [isLoading, setLoading] = useState(false); useEffect(() => { setLoading(true); fetch('/api/books') .then(res => res.json()) .then(books => { setBooks(books); setLoading(false); }); }, []); return ; }; export default BookListContainer;

  5. 使用 styled-components

  对 React 组件进行样式设置一直是个难题。查找拼写错误的类名,维护大型 CSS 文件,处理兼容性问题有时可能很痛苦。

  styled-components 是一个常见的 css in js 类库,和所有同类型的类库一样,通过 js 赋能解决了原生 css 所不具备的能力,比如变量、循环、函数等。

  要开始使用 styled-components,你需要首先安装依赖:

  npm i styled-components

  下面是一个示例:

  import React from 'react'; import styled from 'styled-components'; const Grid = styled.div` display: flex; `; const Col = styled.div` display: flex; flex-direction: column; `; const MySCButton = styled.button` background: ${props => (props.primary ? props.mainColor : 'white')}; color: ${props => (props.primary ? 'white' : props.mainColor)}; display: block; font-size: 1em; margin: 1em; padding: 0.5em 1em; border: 2px solid ${props => props.mainColor}; border-radius: 15px; `; function App() { return ( My 1st Button My 2st Button My 3st Button My 4st Button My 5st Button My 6st Button ); } export default App;

  这只是样式化组件如何工作的一个简单示例,但是它们可以做的还远远不止这些。你可以在其官方文档中了解有关样式化组件的更多信息。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
React开发中,有一些小技巧可以帮提高开发效率和代码质量。以下是一些常用的React开发小技巧: 1. 使用函数组件代替类组件:函数组件具有更简洁的语法和更好的性能,在不需要使用生命周期方法和状态管理的情况下,优先考虑使用函数组件来编写代码。 2. 使用React Fragments来包裹组件:React Fragments可以帮我们避免多余的DOM节点,提高代码的可读性和性能。 3. 使用解构赋值来获取props:使用解构赋值可以更方便地获取和使用props,使代码更简洁。 4. 使用箭头函数来定义组件方法:箭头函数可以解决绑定this的问题,使代码更简洁易读。 5. 使用条件渲染来控制组件显示:使用条件渲染可以根据不同的条件来显示不同的组件或内容,提高代码的灵活性和可复用性。 6. 使用ES6的模板字符串来拼接字符串:使用模板字符串可以更方便地拼接字符串,避免繁琐的字符串拼接操作。 7. 使用PropTypes或TypeScript来进行类型检查:使用PropTypes或TypeScript可以帮我们在开发过程中及时发现潜在的类型错误,提高代码的健壮性和可维护性。 8. 使用React DevTools进行调试:React DevTools是一个强大的调试工具,可以帮我们分析组件的渲染过程、性能优化和状态管理等问题。 这些小技巧可以使React开发更加高效和优雅。但需要根据具体的项目需求和个人经验选择合适的技巧来应用。 <span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [React 开发必须知道的 34个技巧](https://blog.csdn.net/sinat_17775997/article/details/117035521)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值