Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
JavaScript を書き始める前にやっておきたいこと / Kanazawa.js meet...
Search
Kotaro Chiba
January 19, 2020
Programming
1
1.1k
JavaScript を書き始める前にやっておきたいこと / Kanazawa.js meetup #1
Kotaro Chiba
January 19, 2020
Tweet
Share
More Decks by Kotaro Chiba
See All by Kotaro Chiba
JavaScript を書き始める前に知っておきたい JavaScript のこと #05
uruha
1
450
JavaScript を書き始める前に知っておきたい JavaScript のこと #04
uruha
1
480
JavaScript を書き始める前に知っておきたい JavaScript のこと #03
uruha
1
370
DMM.com のフロントエンド 今・今後 / Think ! FrontEnd #01
uruha
1
1.4k
JavaScript を書き始める前に知っておきたい JavaScript のこと #02
uruha
1
1.3k
JavaScript を書き始める前に知っておきたい JavaScript のこと
uruha
1
620
JConf JP Sponsor talk DMM.com / TECH VISION に向けての取り組み
uruha
1
440
Other Decks in Programming
See All in Programming
Amazon Qを使ってIaCを触ろう!
maruto
0
400
Jakarta EE meets AI
ivargrimstad
0
530
subpath importsで始めるモック生活
10tera
0
300
Creating a Free Video Ad Network on the Edge
mizoguchicoji
0
120
Streams APIとTCPフロー制御 / Web Streams API and TCP flow control
tasshi
2
350
ペアーズにおけるAmazon Bedrockを⽤いた障害対応⽀援 ⽣成AIツールの導⼊事例 @ 20241115配信AWSウェビナー登壇
fukubaka0825
6
1.9k
Nurturing OpenJDK distribution: Eclipse Temurin Success History and plan
ivargrimstad
0
890
macOS でできる リアルタイム動画像処理
biacco42
9
2.4k
Compose 1.7のTextFieldはPOBox Plusで日本語変換できない
tomoya0x00
0
190
タクシーアプリ『GO』のリアルタイムデータ分析基盤における機械学習サービスの活用
mot_techtalk
4
1.4k
TypeScriptでライブラリとの依存を限定的にする方法
tutinoko
2
660
役立つログに取り組もう
irof
28
9.6k
Featured
See All Featured
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
26
2.1k
Documentation Writing (for coders)
carmenintech
65
4.4k
The Art of Programming - Codeland 2020
erikaheidi
52
13k
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
0
89
The Pragmatic Product Professional
lauravandoore
31
6.3k
RailsConf & Balkan Ruby 2019: The Past, Present, and Future of Rails at GitHub
eileencodes
131
33k
Save Time (by Creating Custom Rails Generators)
garrettdimon
PRO
27
840
Being A Developer After 40
akosma
86
590k
A Modern Web Designer's Workflow
chriscoyier
693
190k
The World Runs on Bad Software
bkeepers
PRO
65
11k
[RailsConf 2023 Opening Keynote] The Magic of Rails
eileencodes
28
9.1k
Performance Is Good for Brains [We Love Speed 2024]
tammyeverts
6
410
Transcript
JavaScript を書き JavaScript を書き 始める前にやってお 始める前にやってお きたいこと きたいこと Kanazawa.js meetup
#1 Kanazawa.js meetup #1 千葉 弘太郎 千葉 弘太郎
千葉 弘太郎 (ちば こうたろう) 千葉 弘太郎 (ちば こうたろう) Kotaro Chiba
Kotaro Chiba Twitter: Github: Work: DMM.com LLC @ur_uha uruha
みなさん みなさん JavaScript 書いて JavaScript 書いて ますか? ますか?
普段こういうことありませんか? 普段こういうことありませんか? インデントが揃わない 使ってない変数が出てくる カンマやセミコロンがあったりなかったりする やたら一行が長くなって読みづらい etc...
こういうこと意外に こういうこと意外に レビューで指摘しち レビューで指摘しち ゃったりしてません ゃったりしてません か? か?
その時間、実際無駄じゃないですか? 書き方の方針の違いでイライラしちゃいません か? 本来の開発目的とは違うところで疲弊してませ んか?
そんな円環の理から そんな円環の理から 抜け出しませんか? 抜け出しませんか?
JavaScript の書き JavaScript の書き 方は現在ある程度自 方は現在ある程度自 動化できます 動化できます
JavaScript を書き JavaScript を書き 始める前に「書くこ 始める前に「書くこ とを楽にする」準備 とを楽にする」準備 をしましょう をしましょう
その① その① ESLint を導入してソースコー ESLint を導入してソースコー ドの静的検証をする ドの静的検証をする
ESLint とは ESLint とは JavaScript のための静的検証ツール JavaScript のための静的検証ツール
以下のことを検証したりできます インデントや空白の有無 使っていない変数 カンマやセミコロンの使い方 その他、静的検証のルールは自由に切り替え&カ スタムが可能です 個人やチームのレベル・文化にあったルールづく りが可能!
その② その② Prettier を導入してルールに沿 Prettier を導入してルールに沿 ったソースコードに整理する ったソースコードに整理する
Prettier とは Prettier とは JavaScript の記述整理してくれる JavaScript の記述整理してくれる フォーマッタ フォーマッタ
複数人で使えば、ソースコードの記載方法に関 してほとんど差異がなくなります ESLint と組み合わせが可能
つまり... 1. ESLint で静的検証 2. 検証で指摘がある箇所を Prettier で整形 3. 常に均一なソースコードがPRに
ソースコードの品質がこれだけで上がります
Pre-commit で Pre-commit で ESLint / Prettier ESLint / Prettier
pre-commit (git のコミット前) に ESLint / Prettier を使用すると、pull request 前に未然に
ソースコードの記載に関する箇所の修正が可能で す PRやプロダクションコードは常に整理されたソー スコードでレビューを開始できます
ESLint / Prettier ESLint / Prettier を使うと、 を使うと、 JavaScript の書き
JavaScript の書き 方で疲弊しない! 方で疲弊しない!
ただ、変数の命名法やその他人が考えて書かなけ ればならないところはしっかりやっていきましょ う!
まとめ まとめ ESLint / Prettier は JavaScript を書く時の銀の 弾丸ではないけれど、 書き始める前にまず準備しておいて損は無いツー
ル
楽して JavaScript 楽して JavaScript 書きましょう! 書きましょう!