关于javascript:停止犯下这5个JavaScript风格错误

38次阅读

共计 2226 个字符,预计需要花费 6 分钟才能阅读完成。

使你的代码可读和可保护的疾速提醒。

有多少次,你关上一个旧的我的项目,发现凌乱的代码,当你增加一些新的货色时,很容易解体?咱们都有过这样的经验。

为了缩小难以读懂的 javascript 的数量,我提供了以下示例。这些都是我过来所犯过的谬误。

对具备多个返回值的函数应用数组解构

假如咱们有一个返回多个值的函数。一种可能的实现是应用数组解构,如下所示:

const func = () => {
  const a = 1;
  const b = 2;
  const c = 3;
  const d = 4; 
  return [a,b,c,d];
}
const [a,b,c,d] = func();
console.log(a,b,c,d); // 1,2,3,4

只管下面的办法很好用,但的确引入了一些复杂性。

当咱们调用函数并将值调配给 a,b,c,d 时,咱们须要留神返回数据的程序。这里的一个小谬误可能会成为调试的噩梦。

此外,无奈确切指定咱们要从函数中获取哪些值,如果咱们只须要 cd 怎么办?

相同,咱们能够应用对象解构。

const func = () => {
  const a = 1;
  const b = 2;
  const c = 3;
  const d = 4;
  return {a,b,c,d};
}
const {c,d} = func();

当初,咱们能够轻松地从函数中抉择所需的数据,这也为咱们的代码提供了将来的保障,容许咱们在不毁坏货色的状况下减少额定的返回变量。

不对函数参数应用对象合成

假如咱们有一个函数,该函数将一个对象作为参数并对该对象的属性执行一些操作。一种童稚的办法可能看起来像这样:

// 不举荐
function getDaysRemaining(subscription) {
  const startDate = subscription.startDate;
  const endDate = subscription.endDate;
  return endDate - startDate;
}

下面的办法按预期工作,然而,咱们创立了两个不必要的长期援用 startDateendDate

一种更好的实现是对 subscription 对象应用对象解构来在一行中获取 startDateendDate

// 举荐
function getDaysRemaining(subscription) {const { startDate, endDate} = subscription;
  return startDate - endDate;
}

咱们能够更进一步,间接对参数执行对象析构。

// 更好
function getDaysRemaining({startDate, endDate}) {return startDate - endDate;}

更优雅,不是吗?

在不应用扩大运算符的状况下复制数组

应用 for 循环遍历数组并将其元素复制到新数组是简短且相当俊俏的。

能够以简洁明了的形式应用扩大运算符来达到雷同的成果。

const stuff = [1,2,3];

// 不举荐
const stuffCopyBad = []
for(let i = 0; i < stuff.length; i++){stuffCopyBad[i] = stuff[i];
}

// 举荐
const stuffCopyGood = [...stuff];

应用 var

应用 const 保障不能重新分配变量。这样能够缩小咱们代码中的谬误,并使其更易于了解。

// 不举荐
var x = "badX";
var y = "baxY";

// 举荐
const x = "goodX";
const y = "goodX";

果你的确须要重新分配变量,请始终抉择 let 而不是 var

这是因为 let 是块作用域的,而 var 是函数作用域的。

块作用域通知咱们,只能在定义它的代码块外部拜访变量,尝试拜访块内部的变量会给咱们提供 ReferenceError。

for(let i = 0; i < 10; i++){//something}
print(i) // ReferenceError: i is not defined

函数作用域通知咱们,只能在定义其的函数外部拜访变量。

for(var i = 0; i < 10; i++){//something}
console.log(i) // 10

letconst 都是块范畴的。

不应用模板字面值

手动将字符串连贯在一起相当麻烦,而且输出时可能会造成混同。这是一个例子:

// 不举荐
function printStartAndEndDate({startDate, endDate}) {console.log('StartDate:' + startDate + ',EndDate:' + endDate)
}

模板文字为咱们提供了一种可读且简洁的语法,该语法反对字符串插值。

// 举荐
function printStartAndEndDate({startDate, endDate}) {console.log(`StartDate: ${startDate}, EndDate: ${endDate}`)
}

模板文字也提供了嵌入新行的简便办法,你所须要做的就是照常按键盘上的 Enter 键。

// 两行打印
function printStartAndEndDate({startDate, endDate}) {console.log(`StartDate: ${startDate}
  EndDate: ${endDate}`)
}

起源:https://medium.com,作者:Giuseppe Picciano,翻译:公众号《前端全栈开发者》

本文首发于公众号 《前端全栈开发者》,第一工夫浏览最新文章,会优先两天发表新文章。

正文完
 0