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
そろそろWebpackと真剣に向き合ってみる
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
nao-bt
May 04, 2017
Programming
5.1k
9
Share
そろそろWebpackと真剣に向き合ってみる
We Are JavaScripters! @6th【初心者登壇歓迎!LT大会】で使用した資料です。
https://wajs.connpass.com/event/54667/
nao-bt
May 04, 2017
More Decks by nao-bt
See All by nao-bt
僕のフロントエンド奮闘記コンポーネントで、すったもんだ
naotobt
1
1.1k
Other Decks in Programming
See All in Programming
20年以上続くプロダクトでも使い続けられる静的解析ツールを求めて
matsuo_atsushi
0
150
cloudnative conference 2026 flyle
azihsoyn
0
180
〜バイブコーディングを超えて〜 チームで実験し続けたAI駆動開発
tigertora7571
0
210
プラグインで拡張される Context をtype-safe にする難しさと設計判断
kazupon
0
150
(Re)make Regexp in Ruby: Democratizing internals for the JIT
makenowjust
3
1.1k
AlarmKitで明後日起きれるアラームアプリを作る
trickart
0
140
継続的な負荷検証を目指して
pyama86
3
1.2k
How We Practice Exploratory Testing in Iterative Development( #scrumniigata ) / 反復開発の中で、探索的テストをどう実施しているか
teyamagu
PRO
3
840
新規プロダクトを高速で生み出すハーネスエンジニアリング
seanchas116
2
120
「なんか〇〇ライブラリで脆弱性あるみたいなんだけど。。。」から始める脆弱性対応 / First Steps in Vulnerability Response
mackey0225
2
130
AIを導入する前にやるべきこと
negima
2
360
いつか誰かが、と思っていた フロントエンド刷新5年間の実践知
kiichisugihara
1
280
Featured
See All Featured
Optimizing for Happiness
mojombo
378
71k
Digital Projects Gone Horribly Wrong (And the UX Pros Who Still Save the Day) - Dean Schuster
uxyall
0
1.4k
Agile Actions for Facilitating Distributed Teams - ADO2019
mkilby
0
190
Side Projects
sachag
455
43k
Stewardship and Sustainability of Urban and Community Forests
pwiseman
0
200
Statistics for Hackers
jakevdp
799
230k
A Soul's Torment
seathinner
6
2.8k
Navigating the moral maze — ethical principles for Al-driven product design
skipperchong
2
360
Building Better People: How to give real-time feedback that sticks.
wjessup
370
20k
How to build a perfect <img>
jonoalderson
1
5.5k
[RailsConf 2023] Rails as a piece of cake
palkan
59
6.6k
Ten Tips & Tricks for a 🌱 transition
stuffmc
0
110
Transcript
そろそろWebpackと 真剣に向き合ってみる。 NAO-BT
自己紹介 文系出身・プログラミング歴は約4年目 サーバーもフロントもやる人になってきてる。 ※できるとは言っていない。日々勉強中
JSに関しては 4年前 前の会社の研修でちょこっといじる。 約1年前 Angularの1.4系を前の会社の業務で利用。 徐々にJSの面白みを感じ、個人的にフレームワークを中心に 勉強をはじめる(Angular2,React) 現在 サーバーサイドはPHP(フレームワークはLaravel)、 フロントはVue.jsで業務システムのSPAを作っている。
JSのフレームワークで 毎回躓くところ。
ビルドまわりがよくわからん。
なんで必要なのかわかってないから フレームワークのチュートリアルをやるとき、 大体躓く。 グッタリ _(:3 」∠)_
でも最近、 おぜん立てしてもらえるので なんとかなる。 Vue-cli create-react-app Laravel-mix
なんとかなってしまった結果・・・ なんとなくわかった気になる。
いやいや!! 便利ツールによりかかってるだけで、 理解してないよね!? サポートおわったらどうすんの!?
ということで、 JSの知識が少しは身についた今、 もう一度 ビルドまわりと向き合ってみる。
とりあえず、 Webpackと向き合ってみる
Webpackは各CLIで使われている create-react-appのreact-script Vue-cli
そもそもなんで、WebPackを使うの?
★★★ Webアプリを効率よく開発するために 分割したモジュールの 名前解決・依存関係を整理してくれる。 ★ TypeScriptやJSXをトランスパイルする。
JSの役割がWebサイトの 簡単な装飾程度なら、 そんな必要はなかった。 1ファイルにまとめられる程度の量に収まる。
しかし、 非同期通信やDOM操作など 様々な機能をページに盛り込む SPAなサイトを作ろうとすると 大量のJSを書くことになる。 これを一つのファイルに 書き続けることは、かなりしんどい。
大量のJSのコードを モジュールごとにわける サブルーチンやデータ構造を役割ごとに分割したものをモジュールと言います。 モジュール同士の依存性を可能な限り減らし、 保守性を高めて再利用可能にすれば、開発もはかどる!
フレームワーク利用の利点には DOM操作や非同期通信を簡単に書ける! というのもありますが・・・、 それぞれの思想に沿って使えば 最適なモジュール構成になります。 ・MVVM ・コンポーネント指向
そもそも、Javascriptは 「Webのページにちょっと動きを与える言語」 という想定だったので、 言語仕様としてモジュールをサポートしていません。 ビルドツールを使わなければ モジュールパターンというコーディングのテクニックを 使っているにすぎない。 ただし・・・
そのまま、開発しようとすると <head>タグがこんなことに・・・。
JSの悩ましいモジュールの実情 グローバルオブジェクト内の競合や 読み込む順番を間違えると、エラーが起きるので どんなモジュールがあるか開発者は把握していないといけない。 システムが大きくなればなるほど、 <head>タグ内の<script>リストが長くなる。
それを ビルドを通して解決する JS JS JS JS JS JS JS
ビルドとは 複数のソースコードを基に 組み合わせて 実行ファイルを生成する作業。 この中でモジュール間の 名前解決、依存関係の解決を行っている。
Webpackは まずはこれさえ、 分かれば怖くない。 Entry Output Loaders Plugins
Entry コンテキストルートとなるファイルの指定。 そのファイルから依存関係を追跡するようにwebpackに指示します。 Webpack.config.js entry.js module1.js
Output ビルド結果の出力に関する指定。 filenameはビルド後に出力されるファイル名、pathはそのファイルの出力先 Webpack.config.js Index.html
Loaders ビルドの際にモジュールのソースコードに適用される変換を指定します。 これの利用でJS以外の拡張子(jsx/vue/ts/css/img) のものもビルドできるようになります。 package.json 拡張子がcssのファイルをjsに 変換するためLoderを npm install する
拡張子がcssのファイルにインストールした Loaderを使うよう指定 Webpack.config.js
Loaders entry.js modulecss.css Index.html
Loadersではまったところ testってしないとビルドが通らない! Webpack.config.js package.jsonのscriptsみたいに自由に書き換えられるのかと思いきや・・・
Plugins ビルド時の設定を行います。 ビルドする際にファイルの圧縮をおこなったり(UglifyJsPlugin)、 コンパイルエラーが起きてもスキップする設定ができる(NoErrorsPlugin)。
Webpack 2になって変わったこと① Webpackはver2からES2015でjavascriptの新しい言語仕様に採用された import・exportが使えます。 このほかのES2015の仕様を利用したい場合は、LodersでBabelを使用する必要があります。 entry.js module1.js
Webpack 2になって変わったこと② TreeShakingという機能が加わり、 exportしているけどimportされていない モジュールはプロダクションビルドの際に 含まれなくなった。
まだまだ勉強が必要・・・ 「インストールしたフレームワークなどのライブラリーと 開発で作ったアプリケーションのコードはビルドの際には分けておいたほうがいい。」 と言われて、laravel-mix上ではできたんですが、素のwebpackではできなかった・・・。 他にも効率の良いビルドの設定の追求を目指し、お助けツールに頼ってばかりにならないよう チュートリアルを読み込みながら頑張りたい・・・
つたない発表ですみません。 ご清聴ありがとうございました。