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
IntelliJ loves JavaScript #jbnight
Search
Kazuhiro Karino
November 22, 2016
Technology
310
1
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
IntelliJ loves JavaScript #jbnight
JetBrains東京Nightで発表した資料です。
(画像の部分は主にGifを使っていたので実際に試すことをお勧めします)
Kazuhiro Karino
November 22, 2016
Other Decks in Technology
See All in Technology
“詰む”前に仕組みを作れ 〜技術の波に溺れないためのキャッチアップ術〜
takasyou
7
4.2k
WebGIS AI Agentの紹介
_shimizu
0
580
[チョークトーク資料]AWS DevOps Agent を使いこなす / AWS Dev Ops Agent Chalk Talk AWS Summit Japan 2026
kinunori
4
800
從開發到部署全都交給 AI:實作 AI 驅動的自動化流程
appleboy
0
180
気軽に使える"情報のハブ"としてのNotion活用 〜フロー情報の集積点 と、 Claude Code × Notion AI〜
syucream
1
210
Flow 不死:AI 時代 DevOps 的不變本質
cheng_wei_chen
2
550
AIエージェントとPhysical AIが拓く製造業の変革(ハノーバーメッセリキャップ)
iotcomjpadmin
0
160
toB プロダクトから見たWAF
tokai235
0
240
フルカイテン株式会社 エンジニア向け採用資料
fullkaiten
0
11k
Amazon Redshift zero-ETL 統合を活用した軽量なマルチプロダクトデータ可視化基盤 / Lightweight Multi-Product Data Visualization with Amazon Redshift Zero-ETL
kaminashi
0
110
AI時代のコスト管理を考えよう〜明日から使える実践AWSノウハウ~
yoshimi0227
0
930
Fabricをフル活用する AI Agent Hub -製造業特化AIエージェントの設計
iotcomjpadmin
0
150
Featured
See All Featured
The Organizational Zoo: Understanding Human Behavior Agility Through Metaphoric Constructive Conversations (based on the works of Arthur Shelley, Ph.D)
kimpetersen
PRO
0
370
Kristin Tynski - Automating Marketing Tasks With AI
techseoconnect
PRO
0
280
Skip the Path - Find Your Career Trail
mkilby
1
150
Reality Check: Gamification 10 Years Later
codingconduct
0
2.2k
Technical Leadership for Architectural Decision Making
baasie
3
420
Organizational Design Perspectives: An Ontology of Organizational Design Elements
kimpetersen
PRO
1
750
Getting science done with accelerated Python computing platforms
jacobtomlinson
2
240
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.8k
Imperfection Machines: The Place of Print at Facebook
scottboms
270
14k
Avoiding the “Bad Training, Faster” Trap in the Age of AI
tmiket
0
180
The World Runs on Bad Software
bkeepers
PRO
72
12k
Color Theory Basics | Prateek | Gurzu
gurzu
0
370
Transcript
IntelliJ loves JavaScript ヤフー株式会社 狩野 和博
⾃⼰紹介 Kazuhiro Karino (狩野 和博) Tw: @nana4gonta • ヤフー株式会社 CTO室SWAT
• 社内のフロントエンド開発のサポート • その他フロントエンドに関わること 1
今⽇知ってほしいこと 2
IntelliJ(WebStorm)とJavaScriptの関係 • IDEの持つ機能だけで開発に必要なものはほぼ揃う • 様々な拡張機能を⼊れなくて良い • 良いコードを書くためのサポートをしてくれる • 外部ツールの結果を逐次表⽰ •
より良いコードのためにIntelliJの静的解析 3
JavaScript開発のサポート • IDEが基本的な機能を持っている • シンタックスハイライト • 補完 • 静的検査 •
最近の開発環境にも対応 • Babel、TypeScript • React、Angular • ESLint、flow • Mocha、Karma 4
今回話さない内容 • Nodeアプリケーションのデバッグ • テストとの連携 • 端々に出てくるライブラリ・ツールの説明 5
今回話す内容 • ES2016を書き始めるために • 開発をサポートする補完機能の強化 • バグ発⾒のための静的検査 • (若⼲)フレームワークサポート 6
ES2016を書き始めるために • IntelliJで必要な設定変更は2点 • シンタックスの有効化 • 機能の有効化 7
ES2016の有効化 • シンタックスの有効化 • Preferences > Languages & Frameworks >
JavaScript • 機能の有効化 • Preferences > Languages & Frameworks > JavaScript > Libraries 8
ES2016の有効化 • シンタックスの有効化 • ES2016の新規構⽂でエラーを出さないように • 予約語などを補完できるように • 機能の有効化 •
PromiseやWeakMapなどPolyfillが必要な機能で警告を抑制 • 上記機能を補完できるように • ライブラリとしてimportする場合はチェックを⼊れなくて良い • ビルド時にPolyfillを読み込む場合はチェックを⼊れる 9
補完機能の強化 10
補完機能 • 補完はコードを書く上での強⼒なサポーター • typo防⽌ • 脳のバッファを減らす • JavaScriptの補完を強化する⽅法は3つ •
型に基づく補完 • TypeScriptの型定義ファイル • JSDocによる型アノテーション 11
型に基づく補完 • デフォルトでは型と名前をもとに候補の⼀覧が表⽰される • 機能を有効にすることで補完候補を絞ることができる 12
型に基づく補完の有効化 • 設定は以下の場所に • Preferences > Languages & Frameworks >
JavaScript • Only type-based completionにチェック 13
型に基づく組み込み値の補完 • Only type-based completionを有効化 • 組み込みの値、関数に関して補完はほぼ完璧 14
ライブラリの補完 • ライブラリの補完は組み込み値に⽐べて弱い • 補完してほしい内容が出にくい、出てこない 15
型定義による補完機能の強化 • TypeScriptの型定義ファイルをダウンロード • Preferences > Languages & Frameworks >
JavaScript > Libraries • Download... を選択 16
型定義による補完機能の強化 • TypeScriptの型定義ファイルをもとに補完が効くようになる 17
メンバ変数の補完 • メンバ変数も⽂脈から判定できない場合に補完が弱い そもそもこんな雑なコードは書かないというのは置いといて… 18
JSDocによる補完 • 補完を効かせたい変数にJSDocの型アノテーションを書く • @type, @param, @returnといった変数や返り値の型に関わるもの • PHPやRubyなどでもドキュメントコメント補完は有効 •
ただし⽂脈で補完できない ≒ 読みにくいコードの可能性あり 19
静的検査 20
静的検査 • コード品質の確保 • バグになりそうな部分の発⾒ • プロジェクトでのコードスタイルの統⼀化 • IntelliJ上で扱えるのは3つ •
Inspection • ESLint、JSHintなどの外部ツール • flowを利⽤した型検査 21
Inspection • エディタの右端にある⻩⾊や⾚⾊のアレ • バグになりそうな部分を教えてくれる 22
Inspectionの設定 • 設定は以下の場所に • Preferences > Editor > Inspections 23
Inspectionの設定の種類 • 設定は豊富 • Code style issues • Control flow
issues • Probable bugs • etc... • Control flow issuesやProbable bugsは要チェック 24
ESLint • JavaScript向けの構⽂チェッカーの結果を逐次表⽰ 25
ESLintの設定 • 設定は以下の場所に • Preferences > Languages & Frameworks >
JavaScript > Code Quality Tools > ESLint • Enableにチェック • ESLint package: ESLintのあるnode_modulesのパスを⼊⼒ 26
ESLintとReformat Code • IntelliJにはReformat Codeという便利なものがあるが... • IntelliJ内で設定し、IntelliJ内で完結するCode Styleベース • PredefinedにGoogleとかAirBnBとかあると嬉しい…
• スタイルフォーマットは管理しやすいESLintに寄せたい • ESLintを設定しただけでは--fixオプションが使えない • できれば保存時にコードを直してほしい 27
File Watchers • ファイル形式を指定し、コマンドを実⾏するIntelliJプラグイン • gulpやeslint-watch、それらが使っているchokidar-cliもある • 快適にコードを書くためにはFile Watchersのほうが良い •
外部ツールはエディタ画⾯への反映のタイミングが悪い • IntelliJのフォーカスを外してフォーカスし直す必要がある • File Watchersはその場で反映される 28
ESLintとFile Watchers • 以下のように設定 • 必ずImmediate file synchronizationのチェックは外す 29
ESLintとFile Watchers • 保存時に eslint --fix editing_file.js としてコードが修正される • ファイル形式ごとなのでJSXを扱う場合は別途作成すること
• Immediate file synchronization • チェックしたままだとタイプするごとにeslintが⾛る • 鬱陶しくなるので外すこと 30
flow • ES2016のシンタックス有効化と同じところにある • Preferences > Languages & Frameworks >
JavaScript • flow を選択 • IntelliJのStableはESLintのようにツールチップ表⽰できない • 最近リリースされたWebStorm 2016.3では表⽰できる 31
WebStorm 2016.3とflow • 最近StableになったWebStormとflowの組み合わせは良い • IntelliJに来るのはもう少し先のはず... • 型の間違いをエディタ上で指摘してくれる 32
フレームワークサポート 33
React • JSXの構⽂をエラーにしないためにシンタックスの設定 • Preferences > Languages & Frameworks >
JavaScript • JSX または flow を選択 • WebStormにはスタータープロジェクトがある • Create React Appを利⽤したWeb⽤のもの • React Native⽤もある • IntelliJはStatic Webの⼦カテゴリにWeb⽤スターターがある 34
Angular • React同様、WebStormにはスタータープロジェクトがある • Angular 1⽤とAngular 2⽤があるので注意 • Angular 2⽤はTypeScriptで作成されるので注意
• IntelliJは先にAngularJSプラグインを⼊れる • ⼊れたあとStatic Webの⼦カテゴリにスターターが表⽰される • 開発サポート • ng2- で始まるSnippet • angular-cliを利⽤したコードジェネレート 35
まとめ 36
IntelliJのJavaScriptサポートまとめ • ES2016のサポートもOK • 補完機能もOK • 型とドキュメントを利⽤した補完強化 • 静的検査もOK •
組み込みのInspectionでバグ発⾒の可能性アップ • ESLintの結果を表⽰と逐次修正でコードのブラッシュアップ • flowで型チェックして堅牢なコードに • フレームワークもOK • React、Angularの取っ掛かりもある 37
最後に 38
39 Yahoo! JAPANでは⼀緒に活躍したい エンジニアを募集しています ご清聴ありがとうございました
参考資料 40 • IntelliJ IDEA 2016.2 Help • Configuring JavaScript
Libraries • Code Inspection • Using JavaScript Code Quality Tools Using ESLint • Using the Flow Type Checker • Using AngularJS • Using Angular CLI • New Project: React Starter Kit • Using ReactJS in JavaScript and TypeScript
参考資料 • WebStorm 2016.3 Help • Using the Flow Type
Checker • New Project: React Starter Kit • その他 • How can I run eslint --fix on my JavaScript in Intellij-IDEA, Webstorm, other JetBrains IDEs? 41