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
CA 1Day Youth Bootcamp for Frontend LT
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
Taketoshi Aono(青野健利 a.k.a brn)
December 13, 2021
Programming
1.1k
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
CA 1Day Youth Bootcamp for Frontend LT
Taketoshi Aono(青野健利 a.k.a brn)
December 13, 2021
More Decks by Taketoshi Aono(青野健利 a.k.a brn)
See All by Taketoshi Aono(青野健利 a.k.a brn)
document.write再考
brn
6
3.2k
Parsing Javascript
brn
14
9.5k
JSON & Object Tips
brn
1
570
Modern TypeScript
brn
2
880
javascript - behind the scene
brn
3
810
tc39 proposals
brn
0
990
プロダクト開発とTypeScript
brn
7
3k
React-Springでリッチなアニメーション
brn
1
770
javascript internationalization API
brn
0
960
Other Decks in Programming
See All in Programming
AIで効率化できた業務・日常
ochtum
0
140
TAKTでAI駆動開発の品質を設計する
j5ik2o
7
1.3k
ローカルLLMを使ってB2Bサービスを作っていての学び
yaotti
0
200
Make SRE Operations Easier with Azure SRE Agent
kkamegawa
0
6.6k
LLMによるContent Moderationの本番運用の裏側と品質担保への挑戦
suikabar
3
700
Signal Forms: Details & Live Coding @enterJS 2026 in Mannheim
manfredsteyer
PRO
0
150
Vue × Nuxt × Oxc どこまで使える?実運用の現在地
andpad
0
260
Datadog × OpenTelemetry 入門と実践のあいだ
kn_to_maxpno
1
160
Honoでのサプライチェーン侵害対策 〜 3つのライブラリに学ぶ
yusukebe
6
1.3k
軽量Java基盤の設計 DIコンテナに頼らない、長期保守と1秒起動の実現 JJUG CCC 2026 Spring
macha64
0
540
ECSアプリログをFireLensでコスト削減しようとしたけど諦めた話 in Fargate×Node.js
akihisaikeda
2
4.2k
過去最大のMCPアップデート! 2026-07-28 RC版の謎に迫る
licux
6
360
Featured
See All Featured
The Success of Rails: Ensuring Growth for the Next 100 Years
eileencodes
47
8.2k
A designer walks into a library…
pauljervisheath
211
24k
How People are Using Generative and Agentic AI to Supercharge Their Products, Projects, Services and Value Streams Today
helenjbeal
1
220
Heart Work Chapter 1 - Part 1
lfama
PRO
7
36k
Scaling GitHub
holman
464
140k
How Fast Is Fast Enough? [PerfNow 2025]
tammyeverts
3
610
"I'm Feeling Lucky" - Building Great Search Experiences for Today's Users (#IAC19)
danielanewman
230
23k
Game over? The fight for quality and originality in the time of robots
wayneb77
1
200
How to build an LLM SEO readiness audit: a practical framework
nmsamuel
1
780
How To Stay Up To Date on Web Technology
chriscoyier
790
250k
Applied NLP in the Age of Generative AI
inesmontani
PRO
4
2.3k
世界の人気アプリ100個を分析して見えたペイウォール設計の心得
akihiro_kokubo
PRO
71
40k
Transcript
"*ࣄۀຊ෦ͱϑϩϯτΤϯυΤϯδχΞ
Nam e !CSO 5BLFUPTIJ"POP੨݈ར Occupatio n 'SPOUFOE%FWFMPQFS1SPEVDU0XOFS Compan y
$ZCFSBHFOU"*4UVEJPO"*4IJGU OS S $POUSJCVUPSPG7+BWBTDSJQU&OHJOF Abou t IUUQJOGPCODI
Carrie r - 201 0 - ྵࡉWebडୗձࣾʹೖࣾJSFlash(AS2/3)ΛΔ - 201 1
- CyberAgentೖࣾ - ࠂܭଌπʔϧͷཧը໘ɾλά࣮ - TagManagerͷ࣮ - …৭ʑ - 201 8 - AIࣄۀຊ෦Chatbot։ൃͰ։ൃऀ
None
ͭͷࣄۀΛల։
ຊͷ༰ "*ࣄۀຊ෦Ͱಇ͘ ۀγεςϜͱϑϩϯτΤϯυ Γ͕͍
"*ࣄۀຊ෦Ͱಇ͘
"*ࣄۀຊ෦Ͱಇ͘ AIࣄۀຊ෦ͰϑϩϯτΤϯυ։ൃऀ͕ͲΜͳ͜ͱΛ͍ͯ͠Δ͔தʑ૾͠ ͮΒ͍Ͱ͢ΑͶʁ
"*ࣄۀຊ෦Ͱಇ͘ ϝσΟΞܥͷࣄۀ෦ͱϏδωεۀଶ͕ҧ͍·͢ ϝσΟΞܥͷଟ͘ͷࣄۀ෦B2C(Ϗδωε to ίϯγϡʔϚʔ)Ͱɺফඅऀ ʹ࡞ͬͨͷΛఏڙ͢ΔۀଶͰ͢ ҰํAIࣄۀຊ෦͍ΘΏΔB2B(Ϗδωε to Ϗδωε)ͷۀଶ͕ଟ͘ɺπʔϧ ը໘ͷఏڙઌओʹاۀʹͳΓ·͢
ͨͩɺͦͷఏڙઌاۀ͕͞Βʹ͓٬͞Μʹͦͷ··ఏڙ͢Δέʔε͋ΔͷͰɺ B2B2C(Ϗδωε => Ϗδωε => ίϯγϡʔϚʔ)ͱ͍͏ۀଶଟʑ͋Γ·͢ ͦͯ͠B2BͰओʹۀγεςϜͷ։ൃΛߦ͍·͢
"*ࣄۀຊ෦Ͱಇ͘ ͰB2CͱB2BͰ࣮ࡍʹͲΜͳҧ͍͕͋ͬͯɺͲΜͳ࣮͕͋Δͷ͔ ͪΐͬͱ͚ͩݟͯΈ·͠ΐ͏
ۀγεςϜͱϑϩϯτΤϯυ
ۀγεςϜͱϑϩϯτΤϯυ • JS SDKΛ࡞ͬͨΓ • ސ٬͕͏ཧը໘Λ࡞ͬͨΓ • ͓٬͞ΜͷϑϩϯτΤϯυपΓͷΈղܾΛ͠·͢ʂ
8IBUJT+44%, ͓٬͞ΜͷϖʔδʹKBWBTDSJQUͱIUNMͷεχϖοτΛຒΊࠐ·ͤͯΒͬ ͯɺ༷ʑͳࢪࡦΛ࣮ࢪ͢ΔͨΊͷͷ ۀγεςϜͱϑϩϯτΤϯυ
<!-- Global Site Tag (gtag.js) - Google Analytics --> <script
async src="https://www.googletagmanager.com/gtag/js?id=GA_MEASUREMENT_ID"></script> <script> window.dataLayer = window.dataLayer || []; function gtag(){dataLayer.push(arguments);} gtag('js', new Date()); gtag('config', 'GA_MEASUREMENT_ID'); </script>
• ΞΫηεղੳΛͨ͠Γ • WidgetΛදࣔͨ͠Γ • ࠂΛදࣔͨ͠Γ͢Δ ۀγεςϜͱϑϩϯτΤϯυ +44%,ͱ
+44%,։ൃ UI͕ͳ͍߹γϯϓϧʹjavascript/typescriptίʔυʹͳΔͷͰɺϩδοΫ த৺ͷ७ਮͳϓϩάϥϛϯάʹͳΔ͜ͱ͕ଟ͍ ҙ֎ͱOQNʹ͑Δύοέʔδ͕ͳ͍͜ͱ͕ଟͯࣗ͘࡞ίʔυϝΠϯʹ ͳΔέʔε Γ͍ͨ͜ͱ͕ಛघͳέʔε ۀγεςϜͱϑϩϯτΤϯυ
• άϩʔόϧԚછʹؾΛ͚ͭΔ • ͑ΔAPIΛͪΌΜͱఆٛ͢Δ(ෆඞཁͳͷΛ֎ʹग़͞ͳ͍ ) • ͓٬͞ΜͷαΠτ্ͳͷͰηΩϡϦςΟʹؾΛ͚ͭΔ(XSSͱ͔ ) • ύϑΥʔϚϯεʹؾΛ͚ͭΔ
• ͓٬͞ΜͷαΠτ্ͳͷͰόά͕͋Δͱதʑ·͍ͣ … • ϒϥβޓੑ ۀγεςϜͱϑϩϯτΤϯυ +44%,։ൃ
+44%,։ൃ UI͕͋Δ߹͓٬͞ΜͷαΠτʹUIΛ֎෦͔Βߏங͢ΔͷͰɺCSSͷԚ છʹؾΛ͚ͭͨΓɺUIͷͱ͔B2CͷݟඞཁʹͳΔ͜ͱ͕͋Δ ۀγεςϜͱϑϩϯτΤϯυ
ϒϥβޓੑ ΫϥΠΞϯτʹͲͷϒϥβ·ͰରԠ͍ͯ͠Δ͔໌ࣔΛٻΊΒΕΔέʔε ଟ͍ͷͰɺͪΌΜͱରԠ04ϒϥβɾαϙʔτํΛ໌͓֬ͯ͘͠ ۀγεςϜͱϑϩϯτΤϯυ
ཧը໘։ൃ B2Bܥͷࣄۀͩͱ΄΅ඞਢʹͳΔ։ൃ ΫϥΠΞϯτ͕πʔϧΛίϯτϩʔϧͨ͠ΓϨϙʔτΛݟͨΓ͢ΔͨΊͷը ໘ ۀγεςϜͱϑϩϯτΤϯυ
• SSRͱ͔͋·Γ͍Βͳ͍(͋Εྑ͍͚Ͳ ) • CRUDΛඞ࣮ͣ͢Δ • ೝূܥͷݟඞਢ • ҙ֎ͱάϥϑΟοΫඳըܥͷ͕ࣝ͋Δͱ͏໘͕͋Δ(Ϩϙʔτɾͳʹ͔Λ࡞͢Δπʔϧͱ͔ )
• UIίϯϙʔωϯτཧͷݟ • UIɾUXͷઃܭྗ͕ඞਢ • ׂͱ͍͜͠Stateཧ͕͍Δ ۀγεςϜͱϑϩϯτΤϯυ ཧը໘։ൃͷಛ
443ͱ͔͋·Γ͍Βͳ͍ ཧը໘ͲͪΒ͔ͱ͍͏ͱ8FC Core VitalsͷΑ͏ͳͷ͕ڧ͘ٻΊΒΕ͍ͯͳ ͍ͷͰɺSSRແཧͯ͠·ͰΔඞཁͳ͍(Ζ͏ͱͯ͠ೝূ͕͋ΔͷͰ݁ߏେม) ͦΕΑΓৗʹಈ࡞ΛอূͰ͖Δํ͕ॏཁ ͨͩ͠ύϑΥʔϚϯεࣗମۀޮʹ݁͢ΔͷͰɺ$PNQPOFOUͷׂͱ͔ͦͷ͋ ͨΓ͔ͬ͠ΓΔඞཁ͕͋Δ ServiceWorker͏ ͋ͱͦͦϑϩϯτΤϯυଆͷΞϧΰϦζϜͷύϑΥʔϚϯε͕ٻΊΒΕΔ͜ͱ
ଟ͍ ۀγεςϜͱϑϩϯτΤϯυཧը໘։ൃ
$36%Λඞ࣮ͣ͢Δ CRUD(Create,Read,Update,Delete) ࡞ɾಡΈग़͠ɾߋ৽ɾআͷུ ཧը໘Ͱඞͣ͜ͷ͕ͭඞཁʹͳΔ ྫ ChatBotͷγφϦΦ - γφϦΦͷ࡞ $SFBUF -
࡞ͨ͠γφϦΦͷࢀর 3FBE - γφϦΦͷߋ৽ 6QEBUF - γφϦΦͷআ %FMFUF ۀγεςϜͱϑϩϯτΤϯυཧը໘։ൃ
3FBE 6QEBUF $SFBUF %FMFUF
ೝূܥͷࣝඞਢ ඞͣϩάΠϯ͕ඞཁͳͷͳͷͰɺೝূͷΈɾͲͷೝূͰ࣮͢Δ͔ɾ ཁૉೝূɾιʔγϟϧϩάΠϯͱ͔αʔόαΠυνʔϜͱಉ༷ʹࣝΛ Ξοϓσʔτ͓ͯ͘͠ඞཁ͕͋Δ ͨͩࠓͲ͖'JSFCBTF Auth͔ͭͬͨΓ3rd partyͷศརͳೝূػೳ։ൃπʔ ϧΛ͏͜ͱ͕ଟ͍ ۀγεςϜͱϑϩϯτΤϯυཧը໘։ൃ
ҙ֎ͱάϥϑΟοΫܥͷ͕ࣝ͋ΔͱΑ͍ طଘͷϥΠϒϥϦΛ͏ʹͯ͠Ϩϙʔτ47(ɾ$BOWBTΛͬͯඳ ը͢Δ͜ͱ͕ଟ͍ͷͰɺͦͷΜͷ͕ࣝ͋Δͱʹཱͭ ͨͩϨϙʔτʹؔͯ͠֎෦ͷ#*πʔϧΛͬͨΓ͢Δ͜ͱ૿͑ͨͷͰඞ ਢͰͳ͍͔ ͦΕҎ֎ʹը໘ૢ࡞ͰෳࡶͳͷΛઃఆ͢Δέʔεͨ·ʹ͋Δ ۀγεςϜͱϑϩϯτΤϯυཧը໘։ൃ
None
6*ίϯϙʔωϯτཧͷݟ ཧը໘ಉ͡ػೳɾίϯϙʔωϯτΛ܁Γฦ͠͏έʔε͕ଟ͍ͷͰɺ6* ίϯϙʔωϯτΛ͔ͬ͠Γͱཧ͢Δඞཁ͕͋Δ ಛʹଟ͍ͷ͕ɺҰ෦͕ҧ͏ίϯϙʔωϯτɺΞΧϯτͷݖݶʹΑͬ ͯ͑Δػೳ͕ҧ͏ίϯϙʔωϯτ ͜ͷลཧํ๏ʹΑΔ͕ɺྫ͑"UPNJD DesignͳΒatom/moleclues/ organismsΛͪΌΜͱ͢Δඞཁ͕Ͱͯ͘Δ ۀγεςϜͱϑϩϯτΤϯυཧը໘։ൃ
6*69ͷݟ ͓٬͞Μຖը໘Λݟͯ࡞ۀΛ͢ΔͨΊɺ#$ͷ69ͱҧ͏গ͠ҧͬͨ 6*69ͷ࣮͕ٻΊΒΕΔ ۀγεςϜͱϑϩϯτΤϯυཧը໘։ൃ
• ॳݟͰ໎Θͣૢ࡞Ͱ͖Δ͜ͱ • ૢ࡞ʹͳΕͨਓૉૣ͘ૢ࡞Ͱ͖Δ͜ͱ • ૢ࡞ϛε͕ى͖ͮΒ͍͜ͱ(আ֬ೝϙοϓΞοϓग़ͨ͠Γ ) • ΞΫηγϏϦςΟ(͜͜B2Cͱಉ͡) ۀγεςϜͱϑϩϯτΤϯυཧը໘։ൃ
6*69ͷݟ
ॳݟͰ໎Θͣૢ࡞Ͱ͖Δ͜ͱ ॳݟͷਓͰ͍͍͢ͱɺ͠ڝ߹ͱͷπʔϧൺֱΛΫϥΠΞϯτ͕࣮ ࢪ͍ͯͨ͠߹େ͖ͳΞυόϯςʔδʹͳΔ γϯϓϧʹڝ૪ྗʹͭͳ͕Δ ۀγεςϜͱϑϩϯτΤϯυཧը໘։ൃ6*69ͷݟ
ૢ࡞ʹͳΕͨਓૉૣ͘ૢ࡞Ͱ͖Δ͜ͱ πʔϧͷૢ࡞ʹͳΕ͖ͯͨਓ͕ΑΓޮΑ͘ૢ࡞Ͱ͖ΔΑ͏ʹͳΔͱۀ ޮ্͕͕ΓɺπʔϧͷධՁϙΠϯτʹͳΔʢγϣʔτΧοτΩʔͱ͔ʣ ۀγεςϜͱϑϩϯτΤϯυཧը໘։ൃ6*69ͷݟ
ૢ࡞ϛε͕ى͖ͮΒ͍͜ͱ ཧπʔϧ݁ߏக໋తͳૢ࡞Λ࣮ࢪ͢Δ͜ͱ͕͋Δ ԿΒ͔ͷγεςϜͷ ఀࢭɾআ ͷͰɺඞͣ࡞ɾআͷૢ࡞ʹ༷ʑͳํ๏Ͱ֬ೝΛ͢Δ 69ͷઃܭʹ͢Δ ֬ೝϙοϓΞοϓɾ໊લͷ࠶ೖྗ ·ͨૢ࡞ͷޭ࣌ʹ௨ग़͖͢ ۀγεςϜͱϑϩϯτΤϯυཧը໘։ൃ6*69ͷݟ
ΞΫηγϏϦςΟ ͜͜ผʹಛతͰͳ͍ ΈΜͳͪΌΜͱΓ·͠ΐ͏ લड़ͷૢ࡞ͷ͢͠͞ʹ݁͢ΔͷͰ UBCҠಈͱ͔Ͷ ͬͨํ͕γϯϓ ϧʹධՁʹͭͳ͕Γ͍͢ ۀγεςϜͱϑϩϯτΤϯυཧը໘։ൃ
ׂͱ͍͜͠4UBUFཧ Stateཧ͕݁ߏෳࡶʹͳΓ͕ͪ ۀγεςϜͱϑϩϯτΤϯυཧը໘։ൃ
• ओʹCRUDͷ͍ͤ • Loadingঢ়ଶɾ։ดঢ়ଶ͕͍ͬͺ͍ • ೝূঢ়ଶʹΑ͔ͬͯΘͬͨΓ ۀγεςϜͱϑϩϯτΤϯυཧը໘։ൃ 4UBUFཧ
$36%ͷ4UBUFཧ ྫ͑MJTUܥͷΞΠςϜΛ࡞͢Δ߹ - อଘલʹೖྗ͞ΕͨΞΠςϜͷঢ়ଶΛཧ͢Δ - ࡞"1*Λୟ͘ - αʔό͔Β࡞͞ΕͨΞΠςϜͷ*%͕ฦͬͯ͘Δ - Ϧετͷ4UBUFΛߋ৽
ಛʹҰ࣌తͳͷཧΛٻΊΒΕΔέʔε͕ଟ͍ ۀγεςϜͱϑϩϯτΤϯυཧը໘։ൃ4UBUFཧ
-PBEJOHɾ։ดঢ়ଶͱ͔ͷ4UBUFཧ APIΛݺͼग़͍ͯ͠Δؒʹଞͷૢ࡞ΛෆՄೳʹͨ͠ΓɺAPIͷਐߦঢ়گΛݟ ͤΔͨΊʹLoadingΛදࣔ͢Δέʔε͕ଟ͍ ͜ͷ-PBEJOHঢ়ଶΛͲ͏ཧ͢Δ͔͕ࢼ͞ΕΔϙΠϯτ ͋ͱφϏήʔγϣϯͩͬͨΓɺΞΠςϜͷ։ด͕Ͱ͖Δը໘ଟ͍ͷͰɺ ͦΕΒࡶଟͳ6*ͷঢ়ଶཧΛؤுΔඞཁ͕͋Δ ۀγεςϜͱϑϩϯτΤϯυཧը໘։ൃ4UBUFཧ
Γ͕͍
6*ͷແ͍ϑϩϯτΤϯυ ϑϩϯτΤϯυଆͰ७ਮͰෳࡶͳϩδοΫͷ࣮Λ͢Δ͜ͱ͕݁ߏ͋ΔͷͰɺͦ ͏͍͏ͷ͕͖ͳਓ͍ͯΔͱࢥ͍·͢ ݸਓతͳܦݧͱͯ͠1ྫͰ͕͢ - TagManagerͷ࣮ - ϒϥβͷScriptൃՐλΠϛϯάΛશͯίϯτʔϧͨ͠Γ(ϒϥβͷಈ࡞Λ ฿͢ΔͨΊʹ༏ઌ͖ΩϡʔΛ࡞ͬͨΓɺ2ώʔϓ࣮ͨ͠Γ)ɺը໘্Ͱอ ଘ͞ΕͨjavascriptΛͦͷͰίϯύΠϧ͢Δػೳͭͬͨ͘Γ
- ChatBotͷγφϦΦ࡞Ͱ༗άϥϑͷཧɾෛͷॏΈ͖࠷ܦ࿏ΛௐΔ ͳΜ͔ΛͬͨΓ͠·ͨ͠ ͳ͔ͳ͔B2CͰܦݧ͢Δͷ͍͠༰͔ͳͱࢥ͍·͢
Ϗδωεͱ݁ ࡞ͬͨͷ͕ΫϥΠΞϯτʹධՁ͞Εͯɺ͞ΒʹͦΕʹରͯ͠ܖͱ͍ ͏͔ͨͪͰධՁΛΒ͑ΔͷͰB2CΑΓ͔ͳΓతʹධՁ͞Ε·͢ ݸਓతʹ࡞ͬͨͷ͕͍ͯ͘͢ɺۀ͕͔ͳΓվળ͞ΕͨΓɺ͓٬͞ Μͷച্্ʹؔΘΕΔͷ݁ߏ͖Ͱ͢
·ͱΊ
ੋඇɺ"*ࣄۀຊ෦ʂ ͜Μͳײ͡ͷࣄΛ͍ͯ͠ΔͷͰɺڵຯ͕͋Δਓੋඇʂ
͝ਗ਼ௌ͋Γ͕ͱ͏͍͟͝·ͨ͠