某一线前端小组长的 Code Review 分享

点击上方 前端Q,关注公众号

回复加群,加入前端Q技术交流群

☀️ 前言

大家平时网上搜索能搜出一堆Code Review 实践、Code Review 流程、如何如何 Code Review 等等。好像实际的 review 记录并不多,恰好本人有幸担任前端小组长一职,平时摸鱼就去偷偷看看大家又写了什么优秀代码。所以今天就由小弟我,给大家分享一下,小厂一线前端平时写的代码😸

作者能力有限,里面的评论不一定十分正确,仅做记录,抛砖引玉,以供学习参考~

项目背景:

  • react 16.8+

  • antd@4

💻 Talk is cheap. Show me the code!

location.replace 和 location.href的使用区别

94d76786fa4253462a6f45b066ac96e8.jpeg

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

da4f40fe4bf2c93b0f9fd0c1c23e89b5.jpeg

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

Table行点击事件的处理

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

5e8f9d75df62fc28060c1d226cea570c.jpeg

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

6fce855596e48eb730086e6e49a2261c.jpeg

避免使用反直觉的编码

7de2b5e4b17aaef4d35495aa2e580da6.jpeg

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

8c6f9d5ee8e27bda7cea6b4e6d9d01a3.jpeg

没有还原本地测试代码

84bfc640f1b98499552af86ec695098f.jpeg

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

维护好项目内的公共组件

5e436268e33e669144eafa5394eb487e.jpeg

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

3a65177e1077a1bee87539fade03526f.jpeg

方便后续维护

思维固化

d17f0dfe483f51646b27741270c55050.jpeg

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

逻辑不够抽象

dd69b3c7ad1c467d3ed4ca9bcfb755de.jpeg

简单问题复杂化,这一堆 && 是不是看的头大。。

文件名与实际内容不符

168cfa471f6b95d58400f3eee3c07f56.jpeg

命名不规范

2dc7e6502c081419befa5f5ccd55262f.jpeg

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

state 的粒度太细

3f4d98532f03dae442e6402d90f0f367.jpeg

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

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

d2e2c3992108da28762bedb0f600ca2d.jpeg

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

不熟悉 Antd 组件的 api

这里想修改Popover组件内部的样式,想当然的就在外面套多一层div

1824b2e679ea6a6be4e85c47e54c28b8.jpeg

ant-design popover api: overlayClassName[2]

Table 的滚动高度没有自适应

02f33fd33bd06601c0aa93f6f7436011.jpeg

如果用户的显示器大小不一,列表可能展示不全或者只占了一小部分的面积
修改为:scroll={{ y: 'calc(100vh - 表头与顶部距离px)' }}

👋 写在最后

本篇文章整体内容稍微零散,对于没有基础的同学可能不太友好,不过如果大家看完觉得有所收获,可以留言点赞!后续我会继续抽空记录,争取出一系列文章~

dd5001afcd649590e3265b861160088c.png

往期推荐

JavaScript Set新增7个方法

3049729bcca5e37ee695c1e7bf6a6dc5.png

如何实现一个分词器

2b7093279b4e0dbe68ff9d0b5d235863.png

一文吃透 WebSocket 原理

fb8a4f80896b759f448614787af37518.png


最后

  • 欢迎加我微信,拉你进技术群,长期交流学习...

  • 欢迎关注「前端Q」,认真学前端,做个专业的技术人...

bbd2c7846c928f235f68a9c353e5f254.jpeg

be086253b1fa8f6e2ec798bb2b0ec7e6.png

点个在看支持我吧

9c73ab6eee00c70eff31224778ed6933.gif

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值