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
ピクシブの Contentful 利用事情 (2021)
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Hanakla
May 13, 2021
Programming
2
430
ピクシブの Contentful 利用事情 (2021)
Hanakla
May 13, 2021
Tweet
Share
More Decks by Hanakla
See All by Hanakla
Reactルーター選定術 2020年のファイナルアンサー
hanakla
2
5k
動画編集ソフトを作るための基礎知識
hanakla
1
420
Research and Development of "Delir" at Nov, 2016
hanakla
0
160
Other Decks in Programming
See All in Programming
AIによるイベントストーミング図からのコード生成 / AI-powered code generation from Event Storming diagrams
nrslib
2
1.9k
Automatic Grammar Agreementと Markdown Extended Attributes について
kishikawakatsumi
0
200
AI によるインシデント初動調査の自動化を行う AI インシデントコマンダーを作った話
azukiazusa1
1
750
CSC307 Lecture 07
javiergs
PRO
1
560
CSC307 Lecture 10
javiergs
PRO
1
660
コントリビューターによるDenoのすゝめ / Deno Recommendations by a Contributor
petamoriken
0
210
AIと一緒にレガシーに向き合ってみた
nyafunta9858
0
250
OSSとなったswift-buildで Xcodeのビルドを差し替えられるため 自分でXcodeを直せる時代になっている ダイアモンド問題編
yimajo
3
630
AIエージェント、”どう作るか”で差は出るか? / AI Agents: Does the "How" Make a Difference?
rkaga
4
2k
Honoを使ったリモートMCPサーバでAIツールとの連携を加速させる!
tosuri13
1
180
Unicodeどうしてる? PHPから見たUnicode対応と他言語での対応についてのお伺い
youkidearitai
PRO
1
2.6k
KIKI_MBSD Cybersecurity Challenges 2025
ikema
0
1.3k
Featured
See All Featured
実際に使うSQLの書き方 徹底解説 / pgcon21j-tutorial
soudai
PRO
196
71k
WCS-LA-2024
lcolladotor
0
450
The Language of Interfaces
destraynor
162
26k
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
34
2.6k
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
55
3.3k
Leveraging LLMs for student feedback in introductory data science courses - posit::conf(2025)
minecr
0
160
Bridging the Design Gap: How Collaborative Modelling removes blockers to flow between stakeholders and teams @FastFlow conf
baasie
0
450
A designer walks into a library…
pauljervisheath
210
24k
The Mindset for Success: Future Career Progression
greggifford
PRO
0
240
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
194
17k
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
254
22k
Claude Code のすすめ
schroneko
67
210k
Transcript
ピクシブの Contentful 利用事情 (2021) pixiv Inc. Hanakla (はなくら) 2021.5.13
2 お前誰やねん? @hanak1a_ だよ! • VRoid Hubチーム(フロントエンド/バックエンド) • React /
TypeScriptと戯れながらRailsで規約網引き 回しの刑を受けています。たすけてください。 • 意思が強くて悪い顔なヤツらが好き です。 • 普段はオリキャラ系創作界隈で活動しています Hanakla VRoid Hub チーム
話すこと 3 - Contentfulってなに? - 採用事例 - Contentfulの概観 - Content
Modelの設計 話さないこと - 👆以外のContentfulとこの世の真理について
Contentfulってなに? 4
Contentfulとは? Headless CMSと呼ばれる、ヘッドレスなCMSの一つです。(情報量🈚) - エントリの編集画面をContentfulが用意してくれている - カスタムエディタを作ることでJSONに変換可能な任意のエディタとか作れる - 複雑エディタもエンジニアを生贄を捧げて召喚することが出来る -
Contentful Delivery APIを使うことで、エントリをAPIで取得できる - Content Management APIもあるので、”そういうこと”も出来るんじゃないすか? - 多分社内ではまだ採用されていない 5
なぜContentful(CaaS)を使うのか - 頻繁に発生するLPとかニュースのコーディング。秒で終わって欲しいですよね。 - ブチアゲ花火なLPならとにかく、 定常的に増えていくLPのコーディングはシュッと終わって欲しい - ビジネス職の人たちの手で全てが完結できると、原稿のやりとりなどの時間的ロスが 減って楽、エンジニア職も安心して失職出来る -
でもCMSを自前で開発するの面倒じゃん(楽しいけど) - ちゅーかWordPressにしろ自前にしろ、 インフラ整備もしんどい。やらなくていいならやりたくない。 そんなあなたに、Contentful製薬のコンテントフール! 6
ピクシブにおけるContentfulの導入事例 社内ではpixivFACTORY / VRoid Hub / vroid.com で利用されています。 pixivFACTORY: グッズ別LP
/ 特設LP VRoid: VRoid Hub コンテストLP / vroid.com ニュース / VRoid Mobile お知らせ 7
Contentful 使い方 [検索] 8
Contentful 使い方 [検索] 9 流れ 1. Content Model(エントリのスキーマ)を設計します 2. Contentful側でエントリを書きます
3. contentful-任意-clientを使って記事を取得してレンダリングします。 おわり! 制作著作ゥ!!!
Content Modelの設計 10
Content Modelの設計 11 感覚としてはDBのテーブルを設計するのに近い。 1つの記事にどの様なデータが必要かの要件を洗い出してフィールド構造を設計する。
Content Modelの設計 12 フィールドには👉の様なデータ型が あるので、いい感じにModelを設計。 注意点として、Rich Textは 俺たちWebおじさんズが想像するような RichなTextではない……
Content Modelの設計(Rich Textについて) 現状、ContentfulのRich TextはWordpressみたいな感じではない。 色付きテキストや画像リンク・埋め込み画像などは全て別のContent Modelを作ってEmbed Entryするか、生贄を捧げて拡張エディタを作るしかない。 (Slate.jsがよさげ) 13
Rich Textで使えるのは👆👉とH1~6くらい
実際のContent Modelの 設計パターンを見る 14
比較的簡単めなやつ(VRoid NEWS記事) 15 タイトル(ja/en) 公開したことにする日時 アイキャッチ(ja / en) 記事本文(ja /en)
比較的簡単めなやつ(VRoid NEWS記事) 16 Contentfulはフィールド毎にローカライゼーションを行うかどうかを指定できる 1. Settings ⇢ Locales ⇢ 有効にしたいLocaleとデフォルトLocaleを設定
2. フィールドのSettingsで「Enable localization of this field」にチェック
比較的簡単めなやつ(VRoid NEWS記事) 他に、記事中に埋め込むためのボタンコンポーネントや、画像グリッドなどが Content Modelとし て定義されていて、埋め込みEntryとしてRich Textの中に埋め込むことが出来る。 17
変わったContent Model(VRoid Hub) エントリのレンダリング時にAPIとの通信が必要なものは、エントリ側にエンティティへの IDだけ持 たせて、フロントエンドでのレンダリング時に APIとの通信を行う。 VRoid Hubのコンテスト結果発表ページはそのような構成になっている。 18
IDを元にAPIから データを取得 (フロントエンド)
複雑めなやつ(pixivFACTORY) 19 ここらへんは僕が開発したものではないので詳しくはわからない (詳しくは@f_subalへ) https://factory.pixiv.net/special/karadanote_moraeru_campaign
複雑めなやつ(pixivFACTORY) 20 ここらへんは僕が開発したものではないので詳しくはわからない (詳しくは@f_subalへ) https://factory.pixiv.net/special/karadanote_moraeru_campaign
複雑めなやつ(pixivFACTORY) f_subal曰く、ビジネス職の方たちがすぐに慣れてくれたので、 若干項目の多いLPもうまく回っているようです! 21
最高だね!!!! 22
みんなも Contentfulになろう! 23
クライアント側の使い方は 公式ドキュメントを見てくれ 24 JS以外にもPHP, Java .NET, iOS, Ruby向けのSDKがあるぞ https://www.contentful.com/developers/docs/platforms
おわり 25