⚠️ 現在製作中のため、内容は不正確なことがあります。
LAP では、自分のサイトに <script> で埋め込む ブログパーツ として Like API を使った。本記事では同じ API を、自分のサイト以外でも使える ブックマークレット と Chrome 拡張機能 から呼び出す方法を扱う。
LAP の like.js には window.likeApi という共通インターフェースが公開されている。ブックマークレットも Chrome 拡張機能も、これを再利用するだけで動く。同じ API・同じ like.js を別経路から使い回す体験がゴール。
LAP を完了している前提で進める。LAP で https://mk-like-api.pages.dev/like.js が公開されている状態を想定する。Cloudflare 側の追加作業は不要。
LAP の Like API を、任意の Web ページで呼び出す2通りの仕組みを作る:
javascript: URL を1個ブックマークに登録するだけ)全体像:
[ブラウザ] [Cloudflare(LAPで構築済み)]
ブックマークレット
javascript:...(動的<script>差し込み)
↓ load
like.js (LAP配信)
window.likeApi.like() Pages Functions D1
↓ fetch ──────────────────────→ /api/like/:id ──→ pages, likes
Chrome 拡張機能
content_scripts
+ <button> 差し込み
+ like.js を読み込む
↓ window.likeApi.like()
↓ fetch ──────────────────────→ /api/like/:id ──→ pages, likes
2つの方法の対比:
| ブックマークレット | Chrome 拡張機能 | |
|---|---|---|
| インストール | 不要(ブックマーク登録のみ) | 必要(拡張機能を読み込む) |
| 動作タイミング | ブックマーククリック時 | ページを開いた瞬間 |
| UI | アラート / コンソール | ページ上にボタンを差し込み |
| 配布 | URL(javascript: 文字列)を共有 | zip → Chrome ウェブストア |
| 必要な知識 | 1行のJS | manifest.json + content_scripts |
| 制約 | 訪問先サイトの CSP | Manifest V3 の permissions |
GitHub → New repository → リポジトリ名を mk-like-extension で作成。Private にしておく。
名前は別のものでもよい。以降
mk-like-extensionと出てきたら自分のリポジトリ名に読み替える。
このリポジトリには Chrome 拡張機能のソース(manifest.json 等)を入れる。ブックマークレットも一緒に管理する(記録用のテキストファイル)。Cloudflare へのデプロイは不要。
cd ~/Desktop/claude
git clone [email protected]:ユーザー名/mk-like-extension.git
Claudeデスクトップアプリを起動。Code → New session → 作業フォルダ ~/Desktop/claude/mk-like-extension を指定。
ブラウザのブックマークから JavaScript を実行する仕組み。javascript: で始まる URL をブックマークに登録しておくと、ブックマークをクリックしたときにその時開いているページ上でJSコードが実行される。
ロジックは LAP の like.js に集約されているので、ブックマークレット側は like.js を動的に読み込んで、window.likeApi.like() を呼ぶだけにする。
Claude Code に依頼する。
以下の動作をするブックマークレット(javascript: で始まる1行のJS)を作ってください。
- <script> 要素を動的に作って document.body に追加し、
src="https://mk-like-api.pages.dev/like.js" を読み込む
- 読み込み完了(onload)後に window.likeApi.like() を呼び出し、
返り値の { count, liked } をアラートで表示する
例: 「♥ 42 (新規)」「♥ 42 (既にいいね済み)」
IIFE(即時実行関数)でスコープを汚さないこと。
生成後、bookmarklet.txt に保存してリポジトリで管理できるようにしてください。
(執筆予定)
Like!)javascript:... を貼り付け♥ 42 (新規) のような表示ブックマークレットは外部スクリプト(like.js)を動的に読み込むため、訪問先サイトの CSP が厳しい場合は弾かれることがある。GitHub・Twitter / X・Slack・主要な銀行サイトなど、外部スクリプトを一切許可しないサイトでは動かない。
これはブックマークレットの仕様上の制約。動かない場合は、コンソールに Refused to load the script ... のような CSP 違反メッセージが出る。
CSP の緩いサイト(個人ブログ、note、Qiita、Zenn など)では問題なく動く。
CSP で弾かれる場合の代替手段が、次節の Chrome 拡張機能。拡張機能は CSP を超えて動く特権を持つため、ほぼ全サイトで動かせる。
任意のページに「♥ いいね」ボタンを自動で差し込む拡張機能。LAP の like.js をそのまま使うので、共通ロジックの実装は不要。
(執筆予定)
manifest.json + JS/HTML/CSS をまとめたもの主要な構成要素:
manifest.json: 拡張機能の設定ファイル(必須)content_scripts: 訪問先ページのコンテキストで動く JSbackground.js / service_worker: バックグラウンドで動くスクリプト(任意)popup.html: ツールバーアイコンクリック時のUI(任意)permissions / host_permissions: 必要な権限の宣言LEX では content_scripts 中心で構成する。
(執筆予定)
Chrome 拡張機能の manifest.json を作って。Manifest V3 で。
- name: Like Button Injector
- version: 0.1.0
- description: 任意のページに「いいね」ボタンを差し込む
- content_scripts: matches に <all_urls>、js に content.js
- host_permissions: https://mk-like-api.pages.dev/* を追加
host_permissions に LAP の API オリジンを指定することで、content_scripts から fetch ができる。
(執筆予定)
Chrome 拡張機能の content_scripts からは、自前で like.js を読み込んで window.likeApi を使う。直接 fetch を書いてもよいが、LAP と同じロジックを使い回すほうが保守が楽。
content.js を作って。以下の動作をする。
- ページに <button id="like-ext-button" style="position:fixed; bottom:20px; right:20px; z-index:9999; ...">♥</button> を差し込む
- <script> を動的に作って src="https://mk-like-api.pages.dev/like.js" を読み込む
- 読み込み完了後、window.likeApi.getCount() でカウント取得、ボタン表示
- ボタンクリックで window.likeApi.like() を呼び、ボタン表示を更新
ブックマークレットと拡張機能、どちらも 同じ
like.jsを読み込んで、同じwindow.likeApiを使う。「フロントの届け方が違うだけで、本体は1つ」。
(執筆予定)
host_permissions: ["https://mk-like-api.pages.dev/*"] で fetch 先を明示<button> をページの DOM に差し込む処理は、訪問先サイトの DOM/CSP の影響を受ける場合があるブックマークレットでは弾かれる CSP 厳しめサイトでも、拡張機能なら動かせるケースが多い。これが拡張機能を使う最大のメリット。
(執筆予定)
chrome://extensions/ を入力~/Desktop/claude/mk-like-extension フォルダを選択問題があれば chrome://extensions/ で拡張機能の エラー や Service worker のログ を確認する。
(執筆予定)
個人で使うだけなら不要。公開したい場合:
審査では「権限の妥当性」「プライバシーポリシー」「説明文の正確さ」などが見られる。
(執筆予定)
| 状況 | 向いている方法 |
|---|---|
| 自分専用、すぐ試したい | ブックマークレット |
| 友達にも配りたい | ブックマークレット(URL共有) |
| 全ページに自動で出したい | Chrome 拡張機能 |
| CSP 厳しめサイトで動かしたい | Chrome 拡張機能 |
| Chrome ウェブストアで配布したい | Chrome 拡張機能 |
両方とも本質的には「LAP の window.likeApi を呼ぶだけ」。実装の手間と機能性のトレードオフで選ぶ。
(執筆予定)
MutationObserver などで対応)<all_urls> 権限は強い。本番運用なら matches を絞る(執筆予定)
2026-05-21 (last updated: 2026-05-24) タツヲ (yto)