Chrome Extensions Samples 第三回
Google の Chrome 拡張のサンプル集 (GitHub – GoogleChrome/chrome-extensions-samples: Chrome Extensions Samples) から、今日は sample.bookmarks を紹介します。
![](https://ichino-memo.com/wp-content/uploads/2023/08/cbd86e82e880765fec481291d7391ed3-1024x849.png)
読み込んで実行してみる
chrome 拡張のサンプル sample.bookmarks を実行します。読み込む方法や読み込みを確認する方法がわからない場合は以前の記事をご確認頂ければと思います。
![](https://ichino-memo.com/wp-content/uploads/2023/09/4625f3b4aed67e85db5ab170a2b14bf0-1024x397.png)
ソース確認 manifest.json
![](https://ichino-memo.com/wp-content/uploads/2023/09/manifest_bookmarks-1024x279.png)
bookmarks を調べてみます。Google Developers サイトに説明があります。
- chrome.bookmarks
chrome.bookmarks の解説を参照すると、ブックマークを生成したり整理、操作する API です。名前の通りですね。
![](https://ichino-memo.com/wp-content/uploads/2023/09/35a09377a769e50eab1dac61f597e381-1024x282.png)
ソース確認 popup.html
![](https://ichino-memo.com/wp-content/uploads/2023/09/bookmark_head_part.png)
popup.html の head tag の部分です。この部分では jQuery UI を使って chrome 拡張が表示された際の画面部品を提供しています。
![](https://ichino-memo.com/wp-content/uploads/2023/09/bookmark_body_part.png)
popup.html の body tag の部分です。各画面の表示とそれを制御する popup.js が定義されています。
ソース確認 popup.js
このソースは全体で 196 行と長いので、部分的に掲載します。
![](https://ichino-memo.com/wp-content/uploads/2023/09/4c68ced8cd78b379cd5d12099d3b3c2f.png)
popup.js の最下部にある3行は、この chrome 拡張を EventListener を使って読み込み終えることを待っています。読み込み終えたら popup.js の上部にある dumpBookmarks を呼び出します。
![](https://ichino-memo.com/wp-content/uploads/2023/09/dumpBookmarks.png)
dumpBookmarks では chrome.bookmarks.getTree を使ってブックマークの全階層を取得します。この中で dumpTreeNodes や、その中で使われている dumpNode はこの popup.js の中で定義されています。dumpNode 全体を掲載します。この関数は長い定義なのでスクリーンショットを区切っています。
![](https://ichino-memo.com/wp-content/uploads/2023/09/dumpTreeNodes.png)
この関数では与えられた bookmarkNodes 配列内の要素を走査します。各要素に対して dumpNode 関数を呼び出し、要素を表示します。また、要素がフォルダである場合、再帰的にそのフォルダ内の要素を処理します。再帰処理は 187 行からの 3 行で定義されています。
dumpNode では jQuery で定義された関数を呼び出しています。jQuery の API については jQuery API Documentation を参照してください。
![](https://ichino-memo.com/wp-content/uploads/2023/09/9e15ef1cfb2c7ce965ecbb90df730276-1024x1021.png)
この部分 70 行目から 184 行目までは span.hover (マウスオーバー) の処理が定義されています。
![](https://ichino-memo.com/wp-content/uploads/2023/09/3d30a9795392a95d141801ff0358e4a6.png)
![](https://ichino-memo.com/wp-content/uploads/2023/09/899888084019291ac4e0642afd1e3246-1024x984.png)
![](https://ichino-memo.com/wp-content/uploads/2023/09/850d28e997761affe47ea4247e760b7c-972x1024.png)
185 行目からブックマークの階層を維持しながら追加する処理を行っています。
![](https://ichino-memo.com/wp-content/uploads/2023/09/31d7caffb30cffb7358f5b708be5fd00-1024x463.png)
余談
jQuery UI って、既に開発が終了しているのですね。jQuery UI – Wikipedia を参照したらメンテナンスモードへ移行したと記載がありました。開発が継続されている extension は jQuery UI から脱却する必要がありますね。