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
Vue 2 の EOL まで 2 ヶ月ですが進捗どうですか?
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Kobayashi Kazuhiro
October 28, 2023
Programming
1
13k
Vue 2 の EOL まで 2 ヶ月ですが進捗どうですか?
Vue Fes Japan 2023
Special Lunch Session
Kobayashi Kazuhiro
October 28, 2023
Tweet
Share
More Decks by Kobayashi Kazuhiro
See All by Kobayashi Kazuhiro
OpenAPI と型 | Mita.ts #1
kzhrk
0
1.2k
メドピアのサービスにおけるテスト戦略の過去と未来 〜かかりつけ化薬局⽀援サービス kakari 〜
kzhrk
0
74
Other Decks in Programming
See All in Programming
Amazon Bedrockを活用したRAGの品質管理パイプライン構築
tosuri13
5
800
360° Signals in Angular: Signal Forms with SignalStore & Resources @ngLondon 01/2026
manfredsteyer
PRO
0
140
AIフル活用時代だからこそ学んでおきたい働き方の心得
shinoyu
0
140
Automatic Grammar Agreementと Markdown Extended Attributes について
kishikawakatsumi
0
200
Oxlintはいいぞ
yug1224
5
1.4k
Apache Iceberg V3 and migration to V3
tomtanaka
0
170
HTTPプロトコル正しく理解していますか? 〜かわいい猫と共に学ぼう。ฅ^•ω•^ฅ ニャ〜
hekuchan
2
690
humanlayerのブログから学ぶ、良いCLAUDE.mdの書き方
tsukamoto1783
0
200
OSSとなったswift-buildで Xcodeのビルドを差し替えられるため 自分でXcodeを直せる時代になっている ダイアモンド問題編
yimajo
3
630
AIエージェントのキホンから学ぶ「エージェンティックコーディング」実践入門
masahiro_nishimi
6
670
CSC307 Lecture 08
javiergs
PRO
0
670
Best-Practices-for-Cortex-Analyst-and-AI-Agent
ryotaroikeda
1
110
Featured
See All Featured
The Art of Delivering Value - GDevCon NA Keynote
reverentgeek
16
1.8k
JAMstack: Web Apps at Ludicrous Speed - All Things Open 2022
reverentgeek
1
350
Beyond borders and beyond the search box: How to win the global "messy middle" with AI-driven SEO
davidcarrasco
1
58
Agile that works and the tools we love
rasmusluckow
331
21k
Building a Modern Day E-commerce SEO Strategy
aleyda
45
8.7k
New Earth Scene 8
popppiees
1
1.5k
SERP Conf. Vienna - Web Accessibility: Optimizing for Inclusivity and SEO
sarafernandez
1
1.3k
What Being in a Rock Band Can Teach Us About Real World SEO
427marketing
0
170
<Decoding/> the Language of Devs - We Love SEO 2024
nikkihalliwell
1
130
Practical Orchestrator
shlominoach
191
11k
Paper Plane (Part 1)
katiecoart
PRO
0
4.3k
How Fast Is Fast Enough? [PerfNow 2025]
tammyeverts
3
460
Transcript
20 2 3 / 10 / 2 8 (Sat) ⼩林和弘
Vue 2 の EOL まで 2 ヶ⽉ですが、 進捗どうですか? Vue Fes Japan 20 23 Special Lunch Session Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
⾃⼰紹介 Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
メドピアグループの紹介 Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
開発を⽀援する取り組み 輪読会 Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc. •
Vue 3 migration guide • TypeScript Handbook • JS Primer • React 公式ドキュメント
開発を⽀援する取り組み モブプロ • playwright を利⽤した VRT • Next.js プロジェクトの技術選定 •
既存プロジェクトへの bun の適応 Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc. • webpack → rspack の移⾏ • eslint のカスタムルール作成 • vite_rails の適応
開発を⽀援する取り組み スポンサー • Vue Fes Japan 2 023 ゴールドスポンサー •
Vue Fes Japan 2 022 プラチナスポンサー • Vue Fes Japan 2 019 プラチナスポンサー Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
詳細を知りたい⽅は、カジュアル⾯談へ 会社紹介はここまで Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
Vue 2 の EOL まで 2 ヶ⽉ですが、進捗どうですか? Copyright(C) 2023
ALL RIGHTS RESERVED, MedPeer, Inc.
Vue 2 の EOL は 2023/12/31 End of Life を過ぎると…
• 2024 年からは Vue 2 のアップデートが⾏われません • npm や CDN からの配信は引き続き⾏われます • 逃げ道として… • HeroDevs で Vue 2 の有償サポートが提供されています Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
Vue 2 を使い続けてもいいの? Stay on Vue 2 • 最新版の Vue
2 . 7 系であれば技術的には(ある程度)問題ない • script setup • Composition API • セキュリティパッチ更新がない • 社会的な規制、会社のポリシーに抵触するかも Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
Vue 3 へアップデートしましょう メドピアのほとんどのサービスが Vue Copyright(C) 2023 ALL RIGHTS RESERVED,
MedPeer, Inc.
Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
医師専⽤コミュニティサイト MedPeer medpeer.jp • Rails View 上に Vue を乗せる MPA
構成 • vue-router や vuex は未使⽤ • vue ファイルの数: 393(2023-10-13 現在) • Vue 2 . 7 へはアップデート済 Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
eslint の Vue 3 エラーを解消 医師専⽤コミュニティサイト MedPeer • eslint で
Vue 3 のルールでエラーになったファイルを徐々に migrate • plugin:vue/vue 3 -recommended の Vue 3 ルールを有効化 • エラーが発⽣したファイルのルールをオフにする TODO ファイルを作成 • TODO 対象のファイルを Vue 3 の記述に migrate して TODO から削除 Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
eslint の Vue 3 エラーを解消 医師専⽤コミュニティサイト MedPeer Copyright(C) 2023 ALL
RIGHTS RESERVED, MedPeer, Inc.
eslint のカスタムルールで Vue 2 記述を排除 医師専⽤コミュニティサイト MedPeer Copyright(C) 2023 ALL
RIGHTS RESERVED, MedPeer, Inc.
Vue 3 の createApp の Wrapper を作成 医師専⽤コミュニティサイト MedPeer Copyright(C)
2023 ALL RIGHTS RESERVED, MedPeer, Inc.
Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
薬剤師のコミュニティサイト ヤクメド yakumed.jp Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
• Rails View 上に Vue を乗せる MPA 構成 • vuex は未使⽤ • vue ファイルの数: 268(2023-09-06 現在) • Vue 2 . 6 系と Vue 3 系を利⽤(2023-09-06 現在)
Vue 2 と Vue 3 を共存させて徐々に migration 薬剤師のコミュニティサイト ヤクメド Copyright(C)
2023 ALL RIGHTS RESERVED, MedPeer, Inc. • package.json のエイリアスで Vue 3 を個別にインストール • Rails View に紐づくエントリーポイント毎に Vue 3 対応を進める • Vue 3 のテストはモノレポ環境に vitest を導⼊
エントリーポイント単位で Vue 3 対応 薬剤師のコミュニティサイト ヤクメド Copyright(C) 2023 ALL RIGHTS
RESERVED, MedPeer, Inc.
Vue 3 のテストはモノレポで vitest 環境を構築 薬剤師のコミュニティサイト ヤクメド Copyright(C) 2023 ALL
RIGHTS RESERVED, MedPeer, Inc.
Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
特定保健指導の効率化⽀援サービス Tonoel tonoel-mgr.fitsplus.jp Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
• Rails を API として使⽤した Nuxt の SPA構成 • ひとつのリポジトリで 2 つの Nuxt を管理するモノレポ • 初期構築時は Vuex 3 を利⽤ • 初期構築時から Composition API を利⽤ • vue ファイルの数: 163(2023-09-06 現在) • Nuxt 2 . 17 系を利⽤(2023-09-06 現在)
Vuex 3 を Pinia 化 特定保健指導の効率化⽀援サービス Tonoel Copyright(C) 2023 ALL
RIGHTS RESERVED, MedPeer, Inc. • Nuxt 2 系の状態管理ライブラリは Vuex 3 • Vuex 3 は Vue 3 に⾮対応 🤔 • 状態管理ライブラリを Pinia🍍に置き換え
Nuxt 3 の migration ブランチ 特定保健指導の効率化⽀援サービス Tonoel Copyright(C) 2023 ALL
RIGHTS RESERVED, MedPeer, Inc. • Nuxt 3 ⽤の migration ブランチを作成 • Nuxt 3 の migration ガイドに沿って破壊的変更に対応 • https://nuxt.com/docs/migration/overview • テストケースで⾒つかった細かい考慮漏れを対応
Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
医療機関起点の薬局予約サービス やくばと yakubato.jp Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
• Rails を API として使⽤した Nuxt の SPA 構成 • ひとつのリポジトリで 2 つの Nuxt を管理するモノレポ • 初期構築時から Pinia🍍を利⽤ • 初期構築時から Composition API を利⽤ • vue ファイルの数: 157(2023-09-06 現在) • Nuxt 3 に migration 済
とりあえず Nuxt 3 環境をつくる 医療機関起点の薬局予約サービス やくばと Copyright(C) 2023 ALL RIGHTS
RESERVED, MedPeer, Inc. • モノレポ内の 1 つの Nuxt のトップページの表⽰担保のみ対応 • 公式の migration ガイドの通りに設定‧コードを書き換える • Nuxt 3 ⾮対応の modules は⾃前で書き直す • @nuxtjs/axios → axios を⾃前で組み込み • @nuxtjs/gtm → @gtm-support/vue-gtm • ユニットテストがコケるのも気にしない
壊れているところを⼿分けして直す 医療機関起点の薬局予約サービス やくばと Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc.
• 開発環境で発⽣している warning log、error log 対応 • テストをパスするようにする • Storybook を Vue 3 対応する(ついでに vite 化) • eslint ルールを改修 • モノレポの他の Nuxt にも同じ対応を適応
まとめ Vue 2 / Nuxt 2 → Vue 3 /
Nuxt 3 Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc. • 🐢 部分的に徐々に進める • 医師専⽤コミュニティサイト MedPeer • 薬剤師のコミュニティサイト ヤクメド • 🐜 migration ブランチを⽤意して開発と並⾏して進める • 特定保健指導の効率化⽀援サービス Tonoel • 💪 気合で⼀気に進める • 医療機関起点の薬局予約サービス やくばと
Copyright(C) 2023 ALL RIGHTS RESERVED, MedPeer, Inc. ご清聴ありがとうございました https://medpeer.co.jp/recruit/
https://tech.medpeer.co.jp/ 採⽤情報 メドピア開発者ブログ