椒盐豆豉

如何制作一款简单的 chrome 插件

July 19, 2022
重启电脑
code | tutorial | patreon
本文总计 2.88k 字, 阅读约需要 7 分钟

短短几年时间,Chrome 作为一款在主流桌面操作系统(Windows,Mac)不内置的第三方浏览器,短短几年时间击败了所有竞争对手,以压倒性优势 67% 的市场份额稳居桌面端浏览器头把交椅。虽然近年来对其隐私方面顾虑层出不穷,一些 power user 也会试图寻找替代品(Brave,Duckduckgo 之类),但对于绝大多数网民来说还是浏览器的默认选择。

在前端技术越来强大的今天,普通 desktop 用户很多客户端操作都能被网页版替代。拥有庞大的潜在客户群,javascript 上手难度低,浏览器作为运行环境无需担心与系统交互与测试,有 chrome store 管理分发,安装过程也比客户端简单很多,chrome extension(插件)就成了一个对开发者和使用者都轻量、便捷的实用平台。

与此同时,chrome 插件的使用门槛也比让看到代码就头大的用户自己安装油猴 script 低很多,就像跟人安利 app 直接甩 play store 链接肯定比让人下载 apk 容易一样。还有同步的便利(我收到过好几次“为什么不写成油猴 script”的评论……代码就开源在那里,不想走 chrome store 且会用 script 的自然可以去用 script 嘛,反之 store 用户又不能从油猴 script 里轻易变出一个能同步的插件)。

这是拖后了半个月的作业六月 patreon 博客票选胜出的命题(说实话我完全没想到会有这么多人想看开发相关,论我的读者到底有多少码农)。欢迎金主们去七月的投票选出接下来的命题:

  • 我的信息摄取探索 2.0
  • 老年码农合理摸鱼经验总结
  • 非程序员掌握了也很有用的小 hack
  • 美国码农前半段职业发展道路(career ladder)

其实我不知道为什么大家会选这个主题,因为 Chrome 官方的 Developer Guide 写的还蛮清楚的,也给了现成的例子可以抄。不过既然金主们投了,我就来试图给平时不那么经常写程序,但是对自己开发插件有点兴趣的朋友们 TLDR 一下,用我写过的一个简单插件做为例子手把手走一遍开发简单 chrome 插件的过程。

设定目标 #

首先要确定的是,这个插件的功能是什么,它能使哪些用户受益,它的功能是否在浏览器内能够完成。对我来说,开发插件没有什么盈利目的,我也不会把写代码本身当成一项娱乐,因此写插件的唯一目的是自己需要用到这些功能。

我目前上架过两款 chrome 插件:

Kindle notes 导出是我的第一个 chrome 插件,当时刚刚开始构建自己的读书笔记,手头的实体书都读完了开始试图导入电子版,写过一个自用的微信读书笔记导入 Notion 的 python script 之后想要写一个 Kindle 的。但微信读书写 script 更偷懒是因为它的笔记导出方法是直接复制到剪切板,然后我再复制到本地文件里。而 Kindle notes 则集中在一个单独网页上,再手动复制下载多了一个步骤,与其找方法下载不如直接在网页处理,遂写成了 chrome 插件。其逻辑非常简单,就是直接 select 笔记条目的 html tag 然后生成一个 csv。

长毛象原创嘟文则是又有墙内用户大批出逃关注请求审不过来,我自己又不想接受只有转发的号关注,长毛象也只提供了 timeline 上 filter 转发而无法在主页和站外只看原创,因此动了写个插件的念头。逻辑跟 Kindle 的类似,找到转发嘟嘟的 html tag 然后直接 hide。

创造框架 #

虽然说 developer guide 都是 start from scratch,但是相信大多数程序员都懒如我,最熟练的技能是 copy & paste。我的一般流程是找个足够简单但是能跑起来的例子,然后照葫芦画瓢开始改。网上有大把的开源 chrome extension 可以照抄,chrome 官方也提供了一些范例

以我的 Kindle note exporter 为例子,其实只需要三个文件:

  • manifest.json 插件的配置文件,复制官方教程例子再根据自己要用到的 permission 稍加修改即可
  • popup.html 平时在浏览器里点击插件图标会弹出的操作框的 html 文件,随便放个空白页占位。
  • popup.js 执行相关逻辑的 javascript 文件

官方的例子还给了 background.js ,即在后台运行的代码。因为我的插件功能足够简单不需要后台运行,因此我没有添加。(我的 repo 里还有,估计是当时复制粘贴忘了删)

有了这三个基本文件之后你就可以在本地运行测试,chrome 本身也提供了非常简单的测试方法:

  1. 地址栏输入 chrome://extensions 打开插件管理页
  2. 打开右上角的“Developer Mode”选项
  3. 点击“Load unpacked“并且选择你存放刚才三个文件的文件夹

你的新插件就被载入到你本地的 chrome,并且可以实时测试啦。

添加 popup 菜单 #

我对这个插件的设想是点击插件打开菜单小窗,上面有简单的实用指南,导出笔记的按钮,插件的 GitHub repo 链接,和我自己的网站链接。因为是自己用的实用工具所以不需要什么 fancy 效果,随手写了个 html table 排下这几段字和 table。配色则是用我喜欢的 IDE theme solarized light 抓取了对应的颜色。

此外,简单明了的 icon 也不能少,不然看着默认的灰色 icon 我都不想点开它测试。因为我的插件是导出 Kindle notes 到 CSV(以便导入 notion), 我就拿来 Kindle 的 icon 和 notion 的 icon P 了这么一个 图标,竟然还挺满意的(icon 只需要 128 x 128 因此没做高清版):

写好 popup.html 之后,在 manifest.json 里,将图标和其点击动作指向刚刚写好的界面和 logo:

"action": {
    "default_popup": "popup.html",
    "default_icon": {
        "128": "/images/logo.png"
    }
}

刷新 app,刚刚写好的页面正确显示,再进行一些 style 微调,保存所见即所得测试起来很方便,界面部分基本就写完了:

添加逻辑 #

我不想 deal with authorization & maintain login info,因此决定直接从网页爬去 note 内容。这就要保证用户点击 export 按钮的时候处在正确的页面:https://read.amazon.com/notebook 。在 popup.js 添加一个简单的 util function 检查 URL 即可。经过简单检索找到需要的 permission 和如何读取所在页面的 URL。

如果用户不在 note 页面,打开一个窗口将用户跳转去 note 页面即可。从我自己的使用习惯推断,打开插件的时候八成不在 note 页面。因此我又把 html 里 button 的默认 text 换成 go to notes,button onclick action 是跳转页面。

如果用户在 note 页面,button label 换成 export,action 此时需要写核心的导出笔记部分。打开 Kindle notes 网页版 inspect element 找找规律,找到 notes 的相应 tag,iterate 每行将 note 内容推进一个 array 里。

简单检索 chrome extension save csv file,发现一个挺聪明的自动下载方法:

  1. 将内容 join 成一个 Blob
  2. create 一个看不见的 <a> element,把 link 指向刚刚创建的 blob。
  3. 激活这个 link 的 click() 事件。
let csv = notes.map(i => i.join(",")).join("\n");
let csvFile = new Blob([csv], {type: "text/csv"});
let link = document.createElement("a");
link.download = title + ".csv";
link.href = window.URL.createObjectURL(csvFile);
document.body.appendChild(link);
link.click();

测试 #

因为一切都是在浏览器中进行的,所以你可以轻松的 alert/console.log 大法。

打开 manage extension 页面,也可以看到你的测试插件的 error stack trace。

发布 #

如果你不打算在 chrome store 上架,那么恭喜你,你本地测试好的 developer mode 插件已经可以正常使用啦。

不过我还是建议大家上架一下,因为:

  1. 来都来了,说不定发布出去对别人也有用呢?
  2. google developer account 只需要终身 5 刀激活,不像 apple 要 100 刀的年费。买了不吃亏买了不上当。
  3. 上架之后就像其他插件一样可以跟着自己的 Google 账户同步,不用每个设备都重新安装了。

在 https://chrome.google.com/webstore/devconsole/ 注册了账号交了 5 刀保护费之后就可以发布插件了。发布插件过程也比较简单,把之前本地的文件打包成 zip 上传之后填一些信息即可。提交之后审核几天就会发邮件告诉你上架了,此时就可以像其他 web store 里的插件一样搜到或者直接链接了。

来都来了顺势给自己俩插件打个广告好了,如果有因为这篇文章发布了自己插件的朋友们也欢迎回来分享哦:

Migrated Comments

Comment by 马大头 on 2022-07-19 06:01:06 -0700 #

天啊,好有用!椒盐写得好清晰,对我这种“看到代码就头大”但又刚开始尝试用代码满足自己需求的人十分有启发!

Comment by 椒盐鸵鸟 on 2022-07-19 08:00:14 -0700 #

很高兴对你有用!写出来插件了可以回来分享哈哈哈

Comment by Doggieeh on 2022-07-19 21:57:58 -0700 #

椒老师写教程 梦回人人网

相关阅读


<< 前 | 2022 年 6... 随便逛逛 2022 年 7... | 后 >>

如果您觉得本文对您有帮助,想支持我的博客创作,或者有特定的内容想要看到,或者想约 coffee chat 等,欢迎: 订阅 Patreon 参与博客选题和定制服务 在 Kofi 上给我买杯奶茶
❤️ 🤣 🤔 🤯