写法一:
const foo = (data) => {
if(data.length < 3) data = [1,2,3]
return data.map(ele => ele + 1)
}
写法二:
const bar = (data) => {
if(data.length < 3) return bar([1,2,3])
return data.map(ele => ele + 1)
}
这两种写法哪种更好?或者其他更好的写法?
写法一:
const foo = (data) => {
if(data.length < 3) data = [1,2,3]
return data.map(ele => ele + 1)
}
写法二:
const bar = (data) => {
if(data.length < 3) return bar([1,2,3])
return data.map(ele => ele + 1)
}
这两种写法哪种更好?或者其他更好的写法?
1
akatquas Dec 20, 2018 via iPhone
我选第一种,效率和空间都略好一点
|
2
weixiangzhe Dec 20, 2018 via iPhone
2, 不要直接改参数变量 会有不可预计的东西
|
3
Athrob Dec 20, 2018 via Android
个人感觉写法一比较好。写法二 bar 改成 bar2,函数里面也得改。
|
4
Cbdy Dec 20, 2018
```
function bar(data: number[]) { let res = [2, 3, 4] if (data.length > 3) { res = data.map(e => e + 1) } return res } ``` |
5
V2exUser Dec 20, 2018 via Android
第一种,清晰
|
6
Mutoo Dec 20, 2018
2 有 stack overflow 的风险(例如不小心写成 return bar([1,2]) 时,data.length < 3 永远成立)
|
7
dixeran Dec 20, 2018 via Android
所以综合考虑 2L 和 3L,用方法二然后改成 callee?
|
8
Justin13 Dec 20, 2018 via Android
第二个,能纯尽量纯。
或者 ```js const foo = (data) => { const newData = data.length < 3 ? [1,2,3] : data; return newData.map(ele => ele + 1) } ``` |
9
yuanfnadi Dec 20, 2018
const foo = data => {
if (data.length < 3) { return [2, 3, 4]; } return data.map(ele => ele + 1); }; |
10
whileFalse Dec 20, 2018
|
11
otakustay Dec 20, 2018
你不让我写三元的话,肯定选第 2 种,if 分支多起来也是不同分支不同 return。选择不去改变任何一个变量 /参数的值是很好的实践
|
12
wly19960911 Dec 20, 2018
2 的写法究竟是哪里来的。function 减少对外界变量的依赖,这个封装的基础。
const foo = (data) => { if(data.length < 3) return [1,2,3] return data.map(ele => ele + 1) } 这样最好 |
13
cuzfinal Dec 20, 2018
选 2,不要改参数
|
14
yikyo Dec 20, 2018
第一种 ESLint 检测过不去。不能修改参数值。
|
15
jorneyr Dec 20, 2018
只看得懂 1
|