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
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
Lemonade + Foundry Toolkit でお手軽アプリ開発
seosoft
1
360
ユニットテストの先へ:テスト技法で要求・仕様を整理するJava開発実践 / Beyond_Unit_Testing_Practical_Java_Development_Techniques_for_Organizing_Requirements_and_Specifications
shimashima35
0
410
Hunting Vulnerabilities in Symfony with LLMs
vinceamstoutz
0
550
AI 輔助遺留系統現代化的經驗分享
jame2408
1
510
LLMによるContent Moderationの本番運用の裏側と品質担保への挑戦
suikabar
3
700
jQueryをバージョンアップする前に使いたいjQuery Migrate
matsuo_atsushi
0
560
C# and C++ Interoperability - cho-dotnetnew
harukasao
0
180
依存関係から依存物へ―Dependencyという言葉の歴史をひも解く
j_lee
0
120
作って学ぶ、 JSX (TSX) ランタイムの基本
syumai
7
1.6k
フロントエンドとバックエンドで「1文字」を揃えよう
youkidearitai
PRO
0
710
例外の正しい扱い方 そのエラー try-catchして大丈夫?
jinwatanabe
0
260
「なぜそう決めたのか」を残し続ける仕組み ― Notion AI カスタムエージェント × Slack連携による設計判断の自動記録 - NIKKEI Tech Talk #47
niftycorp
PRO
0
200
Featured
See All Featured
Self-Hosted WebAssembly Runtime for Runtime-Neutral Checkpoint/Restore in Edge–Cloud Continuum
chikuwait
0
590
Testing 201, or: Great Expectations
jmmastey
46
8.2k
Un-Boring Meetings
codingconduct
0
320
Agile Actions for Facilitating Distributed Teams - ADO2019
mkilby
0
210
The Organizational Zoo: Understanding Human Behavior Agility Through Metaphoric Constructive Conversations (based on the works of Arthur Shelley, Ph.D)
kimpetersen
PRO
0
360
Prompt Engineering for Job Search
mfonobong
0
350
sira's awesome portfolio website redesign presentation
elsirapls
0
280
A better future with KSS
kneath
240
18k
Facilitating Awesome Meetings
lara
57
7k
My Coaching Mixtape
mlcsv
0
150
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
31
2.8k
Have SEOs Ruined the Internet? - User Awareness of SEO in 2025
akashhashmi
0
370
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ΑΓ͔ͳΓతʹධՁ͞Ε·͢ ݸਓతʹ࡞ͬͨͷ͕͍ͯ͘͢ɺۀ͕͔ͳΓվળ͞ΕͨΓɺ͓٬͞ Μͷച্্ʹؔΘΕΔͷ݁ߏ͖Ͱ͢
·ͱΊ
ੋඇɺ"*ࣄۀຊ෦ʂ ͜Μͳײ͡ͷࣄΛ͍ͯ͠ΔͷͰɺڵຯ͕͋Δਓੋඇʂ
͝ਗ਼ௌ͋Γ͕ͱ͏͍͟͝·ͨ͠