海量新知
5 9 1 5 1 5 8

Code Review 经验

财经快报 | 2022/08/23 10:11:55

项目背景:

  • react 16.8+

  • antd@4

? Talk is cheap. Show me the code! :

location.replace

 和

location.href

的使用区别

正则判断没有对用户可能输入的特殊符号进行转义

解析:

该组件本意是想实现对一串字符中的关键字进行高亮展示; 而正则表达式中有些字符具有特殊的含义,如果在匹配中要用到它本来的含义,需要进行转义(在其前面加一个)。如:

* . ? + $ ^ [ ] ( ) { } | /

Table行点击事件的处理

这里示例代码想实现点击表格行跳转页面效果,但是会导致一些鼠标操作被覆盖

在一个较大的组件内,需要注意输入组件导致的重渲染问题

避免使用反直觉的编码

做好路由字符串拼接的缺省处理

没有还原本地测试代码

解析:

一些本地运行时的mock代码,发到线上时忘记还原代码

维护好项目内的公共组件

使用原生 js 获取 dom 节点,没有使用一个变量来维护 id 值

方便后续维护

思维固化

这位同学可能忘记format函数的入参是可以改的了?

逻辑不够抽象

简单问题复杂化,这一堆

&&

 是不是看的头大。。

文件名与实际内容不符

命名不规范

又是小驼峰又是全大写、又是大写下横线。。

state 的粒度太细

避免一个组件里面有n多行的

useState

避免直接修改对象值,React 要求数据不可变

官网解释: zh-hans.reactjs.org/tutorial/tu…

不熟悉 Antd 组件的 api

这里想修改

Popover

组件内部的样式,想当然的就在外面套多一层

section

ant-design popover api: overlayClassName

Table 的滚动高度没有自适应

如果用户的显示器大小不一,列表可能展示不全或者只占了一小部分的面积

修改为:

scroll={{ y: 'calc(100vh - 表头与顶部距离px)' }}

更多相关内容

更多相关内容

猿巴巴_商业服务平台精选

更多精选内容