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
Nuxt.js x Composition API x TypeScript
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
y-tsuzaki
September 05, 2021
Technology
0
790
Nuxt.js x Composition API x TypeScript
2021年9月8日に行われるNuxt道場 弐面にて発表予定のスライドです。
y-tsuzaki
September 05, 2021
Tweet
Share
More Decks by y-tsuzaki
See All by y-tsuzaki
PHPカンファレンス福岡2024 【超特急】SQLアンチパターン総おさらいLT
ytsuzaki
1
1.5k
PHPカンファレンス北海道2024 リーダブルSQL
ytsuzaki
5
790
ある日PHPerがベンチャー企業のデータ基盤を作ることになったら
ytsuzaki
1
440
【PhpStorm】モブプログラミングの実践と学び【結局はバランス?】
ytsuzaki
0
490
PHPerKaigi 2022 【Laravel】 サクッとN + 1問題を見つけて倒しチャオ!
ytsuzaki
1
3.2k
【超特急】「SQLアンチパターン」 総おさらいLT 【4分で25個】
ytsuzaki
2
890
Nuxt Composition API 使ってみた
ytsuzaki
0
270
PHPerKaigi 2021 LT PHPで簡単コード生成! 同じようなコードをたくさん書くなら コード生成しチャイナ!
ytsuzaki
0
150
アクセス制御ライブラリ Casbinを使ってみた
ytsuzaki
2
1.7k
Other Decks in Technology
See All in Technology
仕様書駆動AI開発の実践: Issue→Skill→PRテンプレで 再現性を作る
knishioka
2
660
モダンUIでフルサーバーレスなAIエージェントをAmplifyとCDKでサクッとデプロイしよう
minorun365
4
210
Kiro IDEのドキュメントを全部読んだので地味だけどちょっと嬉しい機能を紹介する
khmoryz
0
200
CDK対応したAWS DevOps Agentを試そう_20260201
masakiokuda
1
300
20260208_第66回 コンピュータビジョン勉強会
keiichiito1978
0
140
2026年、サーバーレスの現在地 -「制約と戦う技術」から「当たり前の実行基盤」へ- /serverless2026
slsops
2
250
Frontier Agents (Kiro autonomous agent / AWS Security Agent / AWS DevOps Agent) の紹介
msysh
3
170
学生・新卒・ジュニアから目指すSRE
hiroyaonoe
2
620
ClickHouseはどのように大規模データを活用したAIエージェントを全社展開しているのか
mikimatsumoto
0
230
配列に見る bash と zsh の違い
kazzpapa3
1
150
ブロックテーマ、WordPress でウェブサイトをつくるということ / 2026.02.07 Gifu WordPress Meetup
torounit
0
190
プロポーザルに込める段取り八分
shoheimitani
1
280
Featured
See All Featured
Collaborative Software Design: How to facilitate domain modelling decisions
baasie
0
140
RailsConf 2023
tenderlove
30
1.3k
The Straight Up "How To Draw Better" Workshop
denniskardys
239
140k
Product Roadmaps are Hard
iamctodd
PRO
55
12k
A Soul's Torment
seathinner
5
2.3k
技術選定の審美眼(2025年版) / Understanding the Spiral of Technologies 2025 edition
twada
PRO
117
110k
Designing Powerful Visuals for Engaging Learning
tmiket
0
230
StorybookのUI Testing Handbookを読んだ
zakiyama
31
6.6k
Primal Persuasion: How to Engage the Brain for Learning That Lasts
tmiket
0
250
Git: the NoSQL Database
bkeepers
PRO
432
66k
The Power of CSS Pseudo Elements
geoffreycrofte
80
6.2k
State of Search Keynote: SEO is Dead Long Live SEO
ryanjones
0
120
Transcript
Nuxt.js x Composition API x TypeScript 2021年9月8日 Nuxt道場 弐面 株式会社
M&Aクラウド 津崎 善昭
自己紹介 津崎 善昭(つざき よしあき) Twitter: @820zacky 趣味:たまにキャンプ、たまに筋トレ(サボり中) 2019年にM&AクラウドにJoin 本日が人生初の20分登壇
None
プロダクト紹介
LaravelからNuxt.jsへ Laravel(PHP)製のアプリケーション 現在フロントエンドをNuxt.jsに移行中 バックエンドはLaravelでHTTP APIを提供 Composition API(@vue/composition-api)を利用 Typescriptで開発
Nuxt.js選定理由 ページ表示速度改善のためSSRしたい メンバがVue.jsに馴染みがあり導入しやすそう コンポーネントをデザイナーもコーディングできそう Vue.jsのコンポーネントはHTMLに似ている
話すこと Nuxt.js, Compsition API, TypeScript そもそもなんなのか なぜComposition APIなのか メリット、デメリット 開発環境を作る
話さないこと Webの基礎などあんまり細かいこと 他のフレームワークとの比較
各技術ざっくり紹介
Nuxt.jsとは Vue.jsのフレームワーク ルーティング, データ管理(ストア), メタタグ管理などWebフロントエンド開発に必要 な機能が組み込まれている サーバサイドレンダリング(ユニバーサルモード) 静的サイト生成(SSG)
サーバサイドレンダリング、ユニバーサルモードとは? サーバサイドレンダリングとは サーバ側でHTMLを生成するWebアプリケーションの方式 クライアントはHTMLを描画するだけなので高速 反対にブラウザでHTMLを生成するのがクライアントサイドレンダリング(通常の vue.jsやReact) = SPA (Single Page
Application) ユニバーサルモードとは サーバサイドレンダリングをした上で、クライアント側で追加のレンダリングなど を行う方式 クライアントで追加のレンダリングを行うため、動的なサイトを作ることができる 高速でリッチなアプリケーションを実現する
Composition API Vue.jsのコンポーネントをいい感じに書く手法 2020年9月にリリースされたVue 3にて導入された 標準の書き方はOptions APIという コンポーネントからロジックを分離し、再利用可能にする 大規模・複雑なコンポーネントを作る時に便利
Typescript 型のあるJavascriptみたいな言語 TypeScriptからJavascirptに変換(トランスパイル)して使う 型の力でポカミスを防ぐことができる 一方で、強力な型の縛りに翻弄されることもある
なぜComposition APIなのか
処理をまとめられる
(無理矢理拡大した図) data()内にいろんな関心事の変数が定義されている
関心事ごとに変数を用意できる
ロジックを抽出して再利用 ref, reactiveなどのリアクティブな値を作成するメソッドや、onMountedなどのコ ールバック登録するメソッドなど、細かく機能が分割されているため、共通化した いロジックや肥大化したロジックを別ファイルに移することができる。 Options APIではMixinというTrait的なやり方でしか分離できず、再利用性が悪かっ た
Nuxt.jsでComposition APIを使う二つのやり方 @vue/composition-api と @nuxtjs/comopsition-api (2021年9月現在)
@vue/composition-api 従来のやり方 Vueの純正composition-api M&Aクラウドが使っているのはこれ SSRとCSRで値をハイドレーションできない問題があり困った (https://speakerdeck.com/kubotak/nuxt-dot-jsdecompositionapiwoshi-u? slide=16) 弊社ではVuexストアを使って値を共有している
@nuxtjs/comopsition-api = Nuxt Composition API 新しいやり方 nuxt-communityが提供している Nuxt 3 のための実験的なもの
Nuxt 3 ではメソッド名がかわるかもしれない Nuxt固有の機能を使える 弊社もこちらへの意向を検討中
Nuxt Composition API @vue/composition-apiの機能に加えてNuxt固有の機能を提供している useMeta : Metaタグの情報にアクセスするメソッド useAsync : NuxtのAsyncDataフックを使うメソッド
useFetch : NuxtのFetchフックを使うメソッド など reqRef, reqSsrRef, ssrRefなど新しい概念も登場している (まだよくわかってないがSSRとCSRで値を共有する方法っぽい)
メリット、デメリット
メリット Nuxtについて Webアプリケーション開発に必要なものが揃っている SSR、SSGできる Composition APIについて 関心事ごとに処理をまとめて書くことができる 大規模な開発にも耐えられる構成にできる TypeScriptについて 型によるポカミス防止
補間による開発スピード向上 ※ JSで開発したことがないのでわからないけど
デメリット フロントエンド初心者にとっては複雑 Nuxtのコードを書いてるのか、Composition APIを書いてるのか、TypeScriptを書 いてるのかよくわからない @vue/composition-api ではVuexを使わないとSSRとCSRで値を共有化(ハイドレー ション)できない Nuxt Comopsition
APIのreqRef、ssrRefなどの新しい概念が難しい Nuxt.jsはコードが増えるとビルドが遅くなる(開発用ビルドで3分) hard-source-webpack-pluginで負荷軽減してもやっぱり遅い(1分程度) コンポーネントやCSSの更新はビルドが早い(10秒)
Nuxt Composition APIの開発環境を作る
Nuxtインストール yarn create nuxt-app sample-app 言語はTypeScriptを選択する Composition APIを導入する yarn add
@nuxtjs/composition-api 今回は新しいやりかたである@nuxtjs/composition-apiを試してみる
nuxt.config.jsを編集する { buildModules: [ '@nuxt/typescript-build', + '@nuxtjs/composition-api/module' ] }
サーバーを起動する yarn dev localhost:3000でサイトが起動する
サンプルコード https://qiita.com/zackey2/items/8a2675c14d73e91267fe
まとめ Nuxt.js x Composition API x TypeScriptという構成について話した 複雑なアプリケーションを作る場合、Composition APIを導入するとよい 今からComposition
APIを導入するならNuxt Composition API がよさそう TypeScriptもセットアップが簡単なので同時に採用してもよいかも