3
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

DartAdvent Calendar 2014

Day 6

WebStormでDart開発

Last updated at Posted at 2014-12-05

こんにちは、らこです。この記事はDartアドベントカレンダーとWebStormアドベントカレンダー両方に書いてます。(手抜きじゃないです)

Dart用IDEとしてのWebStorm

WebStormは8.0からDartサポートを始め、9.0でもサポート内容が拡張されました。

プロジェクトテンプレート

現在Dart用のプロジェクトテンプレートはWebアプリケーション用とコンソールアプリケーション用の2つです。

image

SDKの切り替え

WebStormはプロジェクトごとにDartSDKが選択できるので、過去のSDKで動かしたいときなどもすぐに切り替えできます。
image

image

入力補完

例えば標準ライブラリのインポートは簡単に補完してくれます。
image

組み込みのLiveTemplateも多いです。
image
一部を紹介。
fb.gif

fs.gif

itr.gif

実行・デバッグ

WebStorm9.0から、HTMLファイルをデバッグ実行するとWebStormが自動でpub serveしてくれるようになりました。(「Pub Serve」ウィンドウが立ち上がる)
image
もちろんブレークポイントで止まります。
image

Unit Testing

Dartのユニットテスト用の実行構成も用意されています。
image
結果の表示もJavaScriptと変わりません。
image

pubコマンド

pub getpub upgradepub buildはpubspec.yamlを開くか、右クリックすることで実行できます。
image
image

まだ未熟な部分

コードフォーマッティングにちょこちょこ課題あり

普段はあまり気にならないのですが、細部が微妙にDartEditorのフォーマットと違うことがあります。WebStormにIssueを投げてみるものの、明らかにおかしいものは修正されますが、それ以外は「フォーマットの明確な仕様がない」と、撥ねられることもあります。難儀です。

プロジェクトテンプレートが貧弱

2種類しかないので、私はこちらで紹介してるStagehandをEmptyProjectで使っています。Terminal最高

静的解析が未熟

明らかに定義元はわかっていて、DartEditorだとジャンプできるのにWebStormだと飛べないことが有ります。例えばlib/src内の隠蔽されたソースコード内のクラスを公開ライブラリがexportしている場合や、showなんかにも対応できてないことがありました。
これはDartだけじゃなくWebStormの言語追加全般に言えますが、ベンダによる静的解析ツール(例えばTypeScriptのtsc等)を使わず、独自の解析をプラグインが行うようになっているので、言語のバージョンアップが激しいとプラグインは追いつきません。その都度Issueを投げてはいますが、明らかにトラッカーを見ると人手が足りてません。待つしか無いです。

まとめ

DartのためにWebStormを買うほどには未だ達していないですが、WebStormを持っているならDartにも使わないともったいないです。書きましょう、Dartを!

3
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?