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
我が家のフロントエンド開発事情 2015年度版
Search
wakamsha
September 24, 2015
Technology
0
75
我が家のフロントエンド開発事情 2015年度版
2015年9月現在、私が取り組んでいる新規開発案件におけるフロントエンド開発環境周りについてまとめたものです。
wakamsha
September 24, 2015
Tweet
Share
More Decks by wakamsha
See All by wakamsha
フロントエンドリアーキテクチャリングと開発チームのスキルトランスファーにおける9ヶ月間の奮闘記
wakamsha
5
4.7k
Vite を使ってアプリケーションに環境変数を参照させる方法を考える
wakamsha
0
1k
小さくはじめる車輪の再発明のすゝめ
wakamsha
0
280
JavaScript ( 時々 TypeScript ) で ゆるやかにはじめる関数型プログラミング
wakamsha
6
2.9k
【codegen は難しくない】Swagger から JavaScript ( TypeScript ) コードを自動生成してコーディングを効率化しよう
wakamsha
4
3.2k
My name is WAKAMSHA - I’m a programmer / web frontend engineer.
wakamsha
1
1.9k
それ、もっとスマートに書けるよ - JavaScript コードをもっと短く、もっとシンプルに書く Tips 4選
wakamsha
9
13k
LP 制作フローを抜本的に改善した話
wakamsha
1
430
20170714_about_fusebox
wakamsha
1
7.3k
Other Decks in Technology
See All in Technology
Building Dashboards as a Hobby
egmc
0
230
Databricks における 『MLOps』
databricksjapan
2
170
推しは推せるときに推せ! プロダクトにフィードバックしていこう
nakasho
0
320
エンジニア候補者向け資料2024.04.24.pdf
macloud
0
3.3k
On Your Data を超えていく!
hirotomotaguchi
2
690
KubeConにproposalを送りたい人へのアドバイス
sat
PRO
3
260
Compose Compiler Metricsを使った実践的なコードレビュー
tomorrowkey
1
220
web-application-security
matsuihidetoshi
0
170
Azure Container Apps + Bicep 〜 こんな感じで運用しています
kaz29
2
480
データベース02: データベースの概念
trycycle
0
160
元インフラエンジニアに成る / Human Resources to Human Relations
bobtani
4
920
「スニダン」開発組織の構造に込めた意図 ~組織作りはパッションや政治ではない!~
rinchsan
3
570
Featured
See All Featured
Embracing the Ebb and Flow
colly
80
4.1k
How GitHub (no longer) Works
holman
304
140k
Building a Modern Day E-commerce SEO Strategy
aleyda
17
6.4k
Building Applications with DynamoDB
mza
88
5.6k
WebSockets: Embracing the real-time Web
robhawkes
59
7k
How To Stay Up To Date on Web Technology
chriscoyier
782
250k
XXLCSS - How to scale CSS and keep your sanity
sugarenia
241
1.2M
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
25
2.3k
Statistics for Hackers
jakevdp
789
220k
It's Worth the Effort
3n
180
27k
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
20
1.9k
Writing Fast Ruby
sferik
621
60k
Transcript
զ͕ՈͷϑϩϯτΤϯυ։ൃࣄ ࢁాथ גࣜձࣾϦΫϧʔτϚʔέςΟϯάύʔτφʔζ - Web application development environment -
ࣗݾհ Զͷ໊લΛݴͬͯΈΖ
ࣗݾհ ࢁాथ !XBLBNTIB גࣜձࣾϦΫϧʔτϚʔέςΟϯάύʔτφʔζ ϑϩϯτΤϯυΤϯδχΞ ݄ೖࣾ ࣾ ϦΫϧʔτʹདྷΔલ6*σβΠφʔϑϩϯτΤϯυΤϯδχΞͱͯ͠ ۀܥΞϓϦέʔγϣϯͷ6*ઃܭ͔Β։ൃ·ͰΛ͍ͬͯͨ
https://ryorisapuri.jp ྉཧαϓϦ
None
http://tech.recruit-mp.co.jp NET BIZ DIV. TECH BLOG
None
͍·औΓΜͰ͍Δࣄ 41"։ൃ͢Δʹ͋ͨΓ࠾༻ͨ͠ςΫϊϩδʔ ͜ΕΒΛ౿·͑ͨզ͕ՈͷϑϩϯτΤϯυ։ൃڥ େ·͔ͳΞϓϦέʔγϣϯߏ αʔόʔଆͱ͏·͘࿈ܞ͢ΔͨΊʹඞཁͳ͜ͱ
"HFOEB
͍·औΓΜͰ͍Δࣄ 41"։ൃ͢Δʹ͋ͨΓ࠾༻ͨ͠ςΫϊϩδʔ ͜ΕΒΛ౿·͑ͨզ͕ՈͷϑϩϯτΤϯυ։ൃڥ େ·͔ͳΞϓϦέʔγϣϯߏ αʔόʔଆͱ͏·͘࿈ܞ͢ΔͨΊʹඞཁͳ͜ͱ
৽نαʔϏεΛ 41"Ͱ࡞͍ͬͯ·͢ Single Page Application
None
8FC4FSWFS
݄ 8FC൛ϦϦʔε Ծ Coming soon...
͍·औΓΜͰ͍Δࣄ 41"։ൃ͢Δʹ͋ͨΓ࠾༻ͨ͠ςΫϊϩδʔ ͜ΕΒΛ౿·͑ͨզ͕ՈͷϑϩϯτΤϯυ։ൃڥ େ·͔ͳΞϓϦέʔγϣϯߏ αʔόʔଆͱ͏·͘࿈ܞ͢ΔͨΊʹඞཁͳ͜ͱ
4JOHMF1BHF"QQMJDBUJPOͳͷͰ +BWB4DSJQU͕େنʹͳΔͷඞવ 5PP'BU'SPOUFOE$PEF
41"ͳͷͰ+BWB4DSJQU͕େنʹͳΔͷඞવ w มԽͷܹ͍͠8FCϑϩϯτΤϯυք۾ w σϑΝΫτελϯμʔυͷੜ·Εʹ͍͘ྖҬ w ͻͱͭͣͭࣗୡͰௐࠪͭͭ͠ɺख୳ΓͰڥߏங w ྲྀߦదʹऔΓೖΕͭͭɺ͔Γ͢͞Λॏࢹ w
ʹ໘ͨ͠Βɺ։ൃͷ࠷தͰ᪳ͳ͘ݟ͢
5ZQF4DSJQU "UZQFETVQFSTFUPG+BWB4DSJQUUIBUDPNQJMFTUPQMBJO+BWB4DSJQU
5ZQF4DSJQU w .JDSPTPGU͕։ൃͨ͠"MU+4 τϥϯεύΠϥ w +BWB4DSJQUͷεʔύʔηοτ શ্Ґޓ w
੩తܕ͚ݴޠ w ܕਪ͋Γ w ѹతଟػೳ w $MBTT *OUFSGBDF "SSPXGVOD (FOFSJD .PEVMF /BNFTQBDFʜ جຊతʹਪʹཔΒͣ શྗͰܕఆٛ͠·͢
5ZQF4DSJQU w +BWB $ʹΠϯεύΠΞ͞Εͨݴޠ༷ w &$."4DSJQUͷ༷Λੵۃతʹ࠾༻͍ͯ͠Δ w ίϯύΠϧޙͷ+4ίʔυඒ͘͠ಡΈқ͍ w طଘ+4ϥΠϒϥϦͷଟ͕͑͘Δ
ॆ࣮ͷܕఆٛϑΝΠϧ
7BOJMMB+4ΑΓͣͬͱߴػೳ͕ͩɺ ಈతܕ͚ͳͷେن։ൃʹ͓͍ͯෆར ෳਓͰ։ൃ͢ΔҎ্ɺܕඞਢཁ݅ ͋ΔఔίʔσΟϯάʹ౷੍͕ͱΕΔ ͦͷ΄͔ީิʹͳͬͨ+4τϥϯεύΠϥ ࠓޙ&4͕ਁಁ͍ͯ͘͜͠ͱΛߟ͑Δͱ ͜ͷ࣌ظʹ͋͑ͯબ͢Δඞཁੑ͍ͱ
ͦͷ΄͔ީิʹͳͬͨ+4τϥϯεύΠϥ &4Ͱॻ͔Εͨ+4ίʔυΛ&4ʹม͢Δ τϥϯεύΠϥ ࠓͷ०ͳٕज़Ͱ͋Δ͕ɺ ΓܕΛ࣋ͨͳ͍ͱ͍͏ཧ༝͔Β/( &4ͷจ๏5ZQF4DSJQUͰ͍͍ͩͨॻ͚ΔͷͰ ͋͑ͯͪ͜Βʹ߆Δཧ༝ബ͍
"OHVMBS+4 4VQFSIFSPJD+BWB4DSJQU.78'SBNFXPSL
"OHVMBS+4 w (PPHMF͕։ൃͨ͠ϑϧελοΫ+4ϑϨʔϜϫʔΫ w ѹతଟػೳ w %BUBCJOEJOH 3PVUJOH $VTUPNEJSFDUJWF %*
1SPNJTF BOENPSFʜ w ಛʹڧྗͳϧʔςΟϯάػೳ41"ʹ͏͚ͬͯͭ w "OHVMBS6*3PVUFSϞδϡʔϧͱΈ߹ΘͤΕ࠷ڧ
$VTUPNEJSFDUJWF ಠࣗͷػೳΛ࣮ͨ͠λάϓϩύςΟΛఆٛͰ͖Δ
"OHVMBS+4º5ZQF4DSJQU 5ZQF4DSJQUͱͷ૬ੑ͕ൈ܈ ίϯτϩʔϥɺαʔϏεɺσΟϨΫςΟϒͳͲ ػೳผʹΫϥεԽ͍͢͠ ͨͩ͠ɺݟগͳΊ άά࣮ͬͯફతͳใຆͲग़ͯ͜ͳ͍
ࠓ࠷०ͳ+4ϑϨʔϜϫʔΫ "OHVMBS+4ͱൺֱͯ͠ݟ͕গͳ͍ ॳ಄·ͩใ͕গͳ͔ͬͨ ͦͷ΄͔ީิʹͳͬͨ+4ϑϨʔϜϫʔΫ +49ͷจ๏͕ಠಛ͗ͯ͢ ೃછΊΔࣗ৴͕࣋ͯͳ͔ͬͨ ҙࣝߴ͍ܥͷਓ͕ͨͪͨΒਪ͍ͯ͠Δ͕ Ͳͷൃݴඑଣ͍͘͞ҹ
3FBDU
"OHVMBS+4͕ྲྀߦΔલօ͜Εʹເதͩͬͨ ΘΓͱૉͳ.7$ 1 ͕ॻ͚Δͷҹ .BSJPOFUUFͱΈ߹ΘͤΕɺࠞಱͱ͕ͪ͠ͳ #BDLCPOFͷίʔυʹ͋Δఔ౷੍͕ͱΕΔ ͜Ε͔Β࡞ΔΞϓϦͷنΛߟ͑Δͱ ྗෆΛײ͡Δ ͦͷ΄͔ީิʹͳͬͨ+4ϑϨʔϜϫʔΫ
$SFBUF+4 "TVJUFPG+BWB4DSJQUMJCSBSJFTBOEUPPMTEFTJHOFEGPSXPSLJOHXJUI)5.-
w $BOWBT"VEJPΛ͍͍ײ͡ʹ͓ੈͯ͘͠ΕΔ w ֤छ"1*͕'MBTI "4 ͷͦΕͱࠅࣅ͍ͯ͠Δ w 5ZQF4DSJQUͱͷ૬ੑ͕ൈ܈ w ϦονίϯςϯπΛදݱ͢ΔՕॴͰ༻
w $BOWBTΛͬͨΞχϝʔγϣϯ w ΦʔσΟΦϑΝΠϧͷ࠶ੜ w ϝσΟΞϑΝΠϧͷඇಉظಡΈࠐΈ $SFBUF+4
͍·औΓΜͰ͍Δࣄ 41"։ൃ͢Δʹ͋ͨΓ࠾༻ͨ͠ςΫϊϩδʔ ͜ΕΒΛ౿·͑ͨզ͕ՈͷϑϩϯτΤϯυ։ൃڥ େ·͔ͳΞϓϦέʔγϣϯߏ αʔόʔଆͱ͏·͘࿈ܞ͢ΔͨΊʹඞཁͳ͜ͱ
ྲྀߦదʹऔΓೖΕΔ ͔Γ͢͞આ໌͢͠͞Λॏࢹ େࣄͳ͜ͱͳͷͰೋճݴ͍·ͨ͠
None
+BWB4DSJQU࣮ߦڥ ͜ΕΛϕʔεʹ։ൃڥΛߏங͠ɺ ༷ʑͳπʔϧΛಈ͔͢ Ұ࣌ظɺJPKTͱରཱ ͍ͯͨͬ͠Ά͍͚Ͳɺ ࠷ऴతʹղͯ͠౷߹ɻ7FS͕ϦϦʔε OPEFKT
λεΫϥϯφʔ (VMQ w 5ZQF4DSJQU 4$44 +BEFͷίϯύΠϧ w ϩʔΧϧαʔόʔͷىಈ w 8FCϑΥϯτͷੜ
w ͦͷଞͳΜͰʜ $ npm install -g gulp ৄ͘͠ฐࣾͷϒϩάΛಡΊʂ IUUQUFDISFDSVJUNQDPKQGSPOUFOEHFUUJOHTUBSUFEHVMQTBTTCPVSCPO
ϑϩϯτΤϯυؔ࿈ͷύοέʔδཧπʔϧ #PXFS "OHVMBS+4 $SFBUF+4 #PPUTUSBQ ͱ͍ͬͨ֎෦ϥΠϒϥϦશͯ͜Εܦ༝Ͱ औಘཧ #SPXTFSJGZ8FCQBDLͷ࠾༻ݕ౼͕ͨ͠ɺ ॾʑͱෆ߹͕͋ͬͨͷͰ٫Լ
$44Λੜ͢ΔϓϦϓϩηοαʔݴޠ 4$44 (VMQܦ༝Ͱ༻͢Δ ͨͩ͠-FTT ͯΊʔμϝͩ 4BTTͰ4UZMVTͰ͓͖ͳͷΛͲ͏ͧ
)5.-Λੜ͢ΔϓϦϓϩηοαʔݴޠ +BEF (VMQܦ༝Ͱ༻͢Δ )BNM4MJNͱඇৗʹΑ͘ࣅͨจ๏͕ͩɺ ػೳͦΕΒʹҰஈྼΔ
+BWB4DSJQUͷϢχοτςετπʔϧ +BTNJOFº,BSNB "OHVMBS+4ͷඪ४ςεςΟϯάϑϨʔϜϫʔΫ ৄ͘͠ฐࣾͷϒϩάΛಡΊʂ IUUQUFDISFDSVJUNQDPKQGSPOUFOEQPTU ςετΛಋೖ͢Δ͔ɺΤϯδχΞͷεΩϧͱ Ϧιʔε ظؒ ʹԠͯ͡ॊೈʹஅ͢Δ͜ͱ εΩϧPSظؒʹෆ͕҆͋ΔͷͳΒ
ܿ͘ΓࣺͯΑ͏
None
5ZQF4DSJQUίϯύΠϥࣗମ͕*%&༻"1*Λ ͍࣋ͬͯΔͨΊɺΤσΟλʹίʔυิͱ͍ͬͨػ ೳΛ͍࣋ͨͤ͢ ίʔυิ5ZQF4DSJQUͷ߹ 7JTVBM4UVEJPͱಉͷิػೳ͕ظͰ͖Δ *OUFMMJ+ͱ4VCMJNF5FYU Λ͍ͬͯ·͢
͍·औΓΜͰ͍Δࣄ 41"։ൃ͢Δʹ͋ͨΓ࠾༻ͨ͠ςΫϊϩδʔ ͜ΕΒΛ౿·͑ͨզ͕ՈͷϑϩϯτΤϯυ։ൃڥ େ·͔ͳΞϓϦέʔγϣϯߏ αʔόʔଆͱ͏·͘࿈ܞ͢ΔͨΊʹඞཁͳ͜ͱ
"OHVMBS6*and5ZQF4DSJQU "SDIJUFDUVSF IUUQTHJUIVCDPNXBLBNTIBBOHVMBSVJ@UZQFTDSJQU
͍·औΓΜͰ͍Δࣄ 41"։ൃ͢Δʹ͋ͨΓ࠾༻ͨ͠ςΫϊϩδʔ ͜ΕΒΛ౿·͑ͨզ͕ՈͷϑϩϯτΤϯυ։ൃڥ େ·͔ͳΞϓϦέʔγϣϯߏ αʔόʔଆͱ͏·͘࿈ܞ͢ΔͨΊʹඞཁͳ͜ͱ
"1*υΩϡϝϯτ ඞਢ
"1*υΩϡϝϯτඞਢ w αʔόʔΫϥΠΞϯτ"1*ͷΈͰΓऔΓ͢Δ w ͲͷΑ͏ͳ +40/ ܗࣜͰ௨৴͢Δͷ͔ৗʹѲ͓ͯ͘͜͠ͱ͕ඞཁ w ։ൃதυΩϡϝϯτΛৗʹ࠷৽ʹ͓ͯ͘͜͠ͱͰೝࣝʹᴥᴪ͕ੜ·Ε ΔͷΛ͙
"1*#MVFQSJOU༷Ͱॻ͔Εͨ .BSLEPXOϑΝΠϧ HVMQBHMJPͰ.BSLEPXOϑΝΠϧ͔Β ੩త)5.-Λੜ దͳαʔόʔʹΞοϓϩʔυ͢Ε ཱͳ"1*υΩϡϝϯτϖʔδ͕ "1*υΩϡϝϯτ࡞πʔϧ HVMQBHMJP "1*#MVFQSJOU ৄ͘͠ฐࣾͷϒϩάΛಡΊʂ
IUUQUFDISFDSVJUNQDPKQEFWUPPMTQPTU
%FNP IUUQTHJUIVCDPNXBLBNTIBUSZ@HVMQUSFFNBTUFSUSZ@BQJ
2" "OZ2VFTUJPOT
5IBOLZPV