react初学难点(使用react的7个避坑案例小结)
react初学难点
使用react的7个避坑案例小结目录
- 1. 组件臃肿
- 2. 直接更改state
- 3. props该传数字类型的值却传了字符串,反之亦然
- 4. list组件中没使用key
- 5. setState是异步操作
- 6. 频繁使用Redux
- 7. 组件没以大写字母开头命名
- 后话
React是个很受欢迎的前端框架。今天我们探索下React开发者应该注意的七个点。
React开发者没有创建必要的足够多的组件化,其实这个问题不局限于React开发者,很多Vue开发者也是。
当然,我们现在讨论的是React
在React中,我们可以创建一个很多内容的组件,来执行我们的各种任务,但是最好是保证组件精简 -- 一个组件关联一个函数。这样不仅节约你的时间,而且能帮你很好地定位问题。
比如下面的TodoList组件:
// ./components/TodoList.js import React from 'react'; import { useTodoList } from '../hooks/useTodoList'; import { useQuery } from '../hooks/useQuery'; import TodoItem from './TodoItem'; import NewTodo from './NewTodo'; const TodoList = () => { const { getQuery, setQuery } = useQuery(); const todos = useTodoList(); return ( <li> <ul> {todos.map(({ id, title, completed }) => ( <TodoItem key={id} id={id} title={title} completed={completed} /> ))} <NewTodo /> </ul> <li> Highlight Query for incomplete items: <input value={getQuery()} onChange={e => setQuery(e.target.value)} /> </li> </li> ); }; export default TodoList;
在React中,状态应该是不变的。如果你直接修改state,会导致难以修改的性能问题。
比如下面例子:
const modifyPetsList = (element, id) => { petsList[id].checked = element.target.checked; setPetsList(petList) }
上面例子中,你想更改数组对象中checked键。但是你遇到一个问题:因为使用相同的引用更改了对象,React无法观察并触发重新渲染。
解决这个问题,我们应该使用setState()方法或者useState()钩子。
我们使用useState()方法来重写之前的例子。
const modifyPetsList = (element, id) => { const { checked } = element.target; setpetsList((pets) => { return pets.map((pet, index) => { if (id === index) { pet = { ...pet, checked }; } return pet; }); }); };
这是个很小的错误,不应该出现。
比如下面的例子:
class Arrival extends React.Component { render() { return ( <h1> Hi! You arrived {this.props.position === 1 ? "first!" : "last!"} . </h1> ); } }
这里===对字符串'1'是无效的。而解决这个问题,需要我们在传递props值的时候用{}包裹。
修正如下:
// ❌ const element = <Arrival position='1' />; // ✅ const element = <Arrival position={1} />;
假设我们需要渲染下面的列表项:
const lists = ['cat', 'dog', 'fish']; render() { return ( <ul> {lists.map(listNo => <li>{listNo}</li>)} </ul> ); }
当然,上面的代码可以运行。当列表比较庞杂并需要进行更改等操作的时候,就会带来渲染的问题。
React跟踪文档对象模型(DOM)上的所有列表元素。没有记录可以告知React,列表发生了什么改动。
解决这个问题,你需要添加keys在你的列表元素中。keys赋予每个元素唯一标识,这有助于React确定已添加,删除,修改了哪些项目。
如下:
<ul> {lists.map(listNo => <li key={listNo}>{listNo}</li>)} </ul>
很容易忘记React中的state是异步操作的。如果你在设置一个值之后就去访问它,那么你可能不能立马获取到该值。
我们看看下面的例子:
handlePetsUpdate = (petCount) => { this.setState({ petCount }); this.props.callback(this.state.petCount); // Old value };
你可以使用setState()的第二个参数,回调函数来处理。比如:
handlePetsUpdate = (petCount) => { this.setState({ petCount }, () => { this.props.callback(this.state.petCount); // Updated value }); };
在大型的React app中,很多开发者使用Redux来管理全局状态。
虽然Redux很有用,但是没必要使用它来管理每个状态。
如果我们的应用程序没有需要交换信息的并行级组件的时候,那么就不需要在项目中添加额外的库。比如我们想更改组件中的表单按钮状态的时候,我们更多的是优先考虑state方法或者useState钩子。
在JSX中,以小写开头的组件会向下编译为HTML元素。
所以我们应该避免下面的写法:
class demoComponentName extends React.Component { }
这将导致一个错误:如果你想渲染React组件,则需要以大写字母开头。
那么得采取下面这种写法:
class DemoComponentName extends React.Component { }
上面的内容提取自Top 10 mistakes to avoid when using React,采用了意译的方式,提取了7条比较实用的内容。
到此这篇关于使用react的7个避坑案例小结的文章就介绍到这了,更多相关react 坑内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
- reactnative ios(详解React Native与IOS端之间的交互)
- vue3.0 如何使用useroute(详解vue3中setUp和reactive函数的用法)
- react实现js控制样式(React + Threejs + Swiper 实现全景图效果的完整代码)
- react 使用实例(React+高德地图实时获取经纬度,定位地址)
- html5创作(HTML5录音实践总结Preact)
- react中state的作用是什么(React中useEffect 与 useLayoutEffect的区别)
- vscode react插件(基于visual studio code + react 开发环境搭建过程)
- react组件之间通信(React传递参数的几种方式)
- react新手指引页面编写(React+TypeScript进行项目构建案例讲解)
- react动态创建菜单并实现局部刷新(使用react-virtualized实现图片动态高度长列表的问题)
- react动态添加组件属性(react使用antd的上传组件实现文件表单一起提交功能完整代码)
- react基础知识详解(如何深入理解React的ref 属性)
- react常见问题(React编程中需要注意的两个错误)
- yii2对比springboot(yii2.0框架使用 beforeAction 防非法登陆的方法分析)
- react代码展示(教你如何从 html 实现一个 react)
- react代码质量检查(react如何实现一个密码强度检测器详解)
- 宁夏灵武恐龙化石发现始末(宁夏灵武恐龙化石发现始末)
- 到了岁末 临门一脚 节点,天台综合督评会目标直指 全年红(到了岁末临门一脚)
- 寒假余额不满24小时,不如来一场说走就走的亲子阅读之旅(寒假余额不满24小时)
- 省委书记出席的交流会,十位县委书记同场发言,代表公文材料的高水平(省委书记出席的交流会)
- 《刘老根3》热播,去世15年的她却再次被 伤害(去世15年的她却再次被)
- 十二星座爱情支配欲指数(十二星座爱情支配欲指数)
热门推荐
- python mongodb 基本操作(Python使用pymongo库操作MongoDB数据库的方法实例)
- sqlserver2014怎么重新激活(解决Windows 10家庭版安装SQL Server 2014出现.net 3.5失败问题)
- display flex 布局(解决display:flex属性 justify-content: space-between换行后的排版问题)
- php回收机制(PHP session垃圾回收机制实例分析)
- 服务器怎么用虚拟内存(windows云服务器提示虚拟内存不足的解决方案)
- html5清除浮动的方法(HTML5实现移动端点击翻牌功能)
- tomcat优化jvm(Tomcat修正JDK原生线程池bug的实现原理)
- php扩展安装示例(php扩展开发入门demo示例)
- sqlserver新建表参数错误(Sql Server中判断表、列不存在则创建的方法)
- C# Task实现多线程
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9