JavaScript에서 후행 쉼표를 사용하고 있습니까?
그리고 나는 또한 그것들의 대부분이 단일 라인이 아니라는 것을 확신합니다. 이러한 배열과 객체는 여러 라인으로 퍼져 있습니다.
내 질문은 다음과 같습니다.
Do you leave a trailing comma at the end of the last item before closing the object or array creation?
후행 쉼표를 사용하지 않는다면 그 이유는 무엇입니까?
후행 쉼표가 도움이 되는 이유부터 시작하겠습니다.
후행 쉼표를 유지하는 이유
False diff 카운트 없음
커밋 메시지는 항목을 추가하거나 제거할 때 정확히 같은 줄에 표시됩니다. 즉, 잘못된 diff 카운트가 없습니다 🤥
const ACTIONS = {
ADD_ITEM: 'ADD_ITEM',
- UPDATE_ITEM: 'UPDATE_ITEM'
+ UPDATE_ITEM: 'UPDATE_ITEM',
+ DELETE_ITEM: 'DELETE_ITEM'
}
여기에
+2-1
의 diff 카운트가 있습니다.또는
const ACTIONS = {
ADD_ITEM: 'ADD_ITEM',
UPDATE_ITEM: 'UPDATE_ITEM',
+ DELETE_ITEM: 'DELETE_ITEM',
}
그리고 여기에
+1
의 diff 카운트가 있습니다.Which one do you prefer to in the Pull/Merge Requests?
새로운 아이템은 항상 마지막에
여러 줄 변경을 피하기 위해 중간에 있는 대신 개체 또는 배열의 끝에 새 항목을 추가할 수 있습니다. 👻
위의 예를 고려할 때 편집 횟수를
1
Line으로 유지하려면 개체 중간에 새 항목을 추가해야 합니다.const ACTIONS = {
ADD_ITEM: 'ADD_ITEM',
+ DELETE_ITEM: 'DELETE_ITEM',
UPDATE_ITEM: 'UPDATE_ITEM'
}
또는 후행 쉼표를 사용하고 항상 개체 끝에 새 항목을 추가할 수 있습니다.
const ACTIONS = {
ADD_ITEM: 'ADD_ITEM',
UPDATE_ITEM: 'UPDATE_ITEM',
+ DELETE_ITEM: 'DELETE_ITEM',
}
생산 중단에 대한 두려움 없음
트랜스파일러와 번들러는 후행 쉼표를 생략하고 프로덕션을 중단하지 않습니다 😉
최신 브라우저는 ES5 표준의 일부이므로 후행 쉼표에 대해 불평하지 않습니다.
그러나 이전 브라우저는 IE9 이전에 불평할 수 있습니다.
그런 오래된 브라우저를 찾는 것은 좋은 탐험이지만. 우리는 번들러가 프로덕션 번들에서 후행 쉼표를 생략하여 안전하게 배송할 수 있도록 할 수 있습니다.
그 오래된 브라우저의 경우 후행 쉼표가 가장 작은 문제입니다. 대형 JS 앱을 구문 분석하고 실행할 수 있는 구형 브라우저의 기능도 의심스럽기 때문입니다.
JavaScript 소스 코드에서 후행 쉼표를 활성화하려면 babel 구성에서 babel-plugin-syntax-trailing-function-commas을 사용하십시오.
다음과 함께 Prettier , you can configure 을 사용하는 경우:
trailingComma
.prettierrc
--trailing-comma
만약 using Prettier via CLI가능한 값은 다음과 같습니다.
es5
배열 및 개체에만 해당none
아무데도, 후행 쉼표 없음all
; 배열, 객체, 함수 매개변수 등편견
뭔가 빠진 것 같다
나는 이 주장을 여러 번 들었다. 뒤에 쉼표가 있으면 무언가가 누락되었거나 잘못된 것처럼 느껴집니다.
You will get used to it.
We have got used to writing HTML in JS, trailing comma is a very small thing in front of it.
왜 쓸데없이 캐릭터를 추가해야 합니까?
이 쉼표는 실행에 유용하지 않은 추가 문자입니다.
We write code in Clean way for other developers to understand.
Machines can understand comma or no-comma in the same way. Then why not help the other developers in reviewing the code.
참고문헌
javascript - Are trailing commas in arrays and objects part of the spec? - Stack Overflow
결론
후행 쉼표의 이점은 적지만 매우 좋습니다.
후행 쉼표에 대해 어떻게 생각하십니까?
댓글 💬 또는 Twitter 및/또는
이 기사가 도움이 되었다면 다른 사람들과 공유해 주세요 🗣
블로그를 구독하면 받은 편지함으로 바로 새 게시물을 받을 수 있습니다.
2020년 9월 1일 https://time2hack.com에 원래 게시되었습니다.
Reference
이 문제에 관하여(JavaScript에서 후행 쉼표를 사용하고 있습니까?), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/time2hack/are-you-using-trailing-commas-in-your-javascript-1866텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)