插件废土课:打造属于你的“智能笔记”!

哎呀嘞,亲爱的网页冲浪者们,抓紧浮板,我们要继续在Chrome插件的海浪上翻滚啦!上次我们玩了个小把戏,搞了个显示时间的Hello World插件,这次我们要把游戏玩大,准备打造一个能让你在网页上乱涂乱画的“智能笔记”插件。想象一下,在你那些最爱的网页上留下你智慧的印记,然后下次回来,它们还在那儿等着你,是不是很酷?

这个高级玩意儿将会有这么几个花样:

  1. 右键菜单 —— 右击来一发,随时加笔记。
  2. 内容脚本 —— 选中文字就像选中你的小心心。
  3. 页面涂鸦 —— 在网页上留下你的痕迹,就像海边留下足迹。
  4. 存储回忆 —— 用Chrome存储API记下你的点点滴滴,想看就看。
  5. 弹出界面 —— 一个小窗口让你管理你的秘密笔记。
  6. 后台大脑 —— 管理全局思维,说不定还能把你的笔记传到Google Drive云端呢。

开篇

本章我们要聊聊后台脚本(Service Worker),这玩意儿就像插件的幕后英雄,默默无闻地听着浏览器的耳语,比如插件安装或更新的小秘密。

先来揭秘后台脚本的神秘面纱:
在Chrome插件世界里,后台脚本就是那个不怎么爱出风头的重要角色。它在后台默默工作,监听各种事件,保持插件的全局和谐,有时候还得干干定时任务之类的活儿。虽然它不和用户直接亲密接触,但它是连接内容脚本、弹出页面、选项页面等的大管家。

好了,下面我们开个小差,看看怎么设置这个后台大脑吧。

manifest.json:

首先,咱们得确保manifest.json文件里,后台脚本声明得漂亮:

{"manifest_version": 3,"name": "智能笔记","version": "1.0","background": {"service_worker": "background.js"},"permissions": ["storage"],"action": {"default_popup": "popup.html","default_icon": "icon.png"},"icons": {"48": "icon.png"}
}

这段代码就像是一张插件的身份证,告诉你它叫“智能笔记”,1.0版,用background.js当自己的大脑,还声明了它需要的权限和它那帅气的小图标。

background.js:

接着,敲出你的background.js,赋予它聪明的大脑,让它能聆听浏览器的细语:

// 监听扩展安装事件
chrome.runtime.onInstalled.addListener(function(details) {if (details.reason === "install") {console.log("感谢您安装智能笔记插件!");// 这里可以做一些插件安装后的庆祝活动} else if (details.reason === "update") {console.log("智能笔记插件已经升级到最新版!");// 可以处理一下升级后的事宜}
});

在background.js里,咱们用addListener方法给chrome.runtime.onInstalled事件加了个监听器,根据插件是被安装还是更新,我们在控制台放了几句好话。真实场景中,你可能得在这时候做一些初始化的动作,比如跳个小舞什么的。

你知道吗,开发Chrome扩展时,我们会总是重新加载插件测试新招数。onInstalled事件就像是一个试衣间,每次你装上新衣服或者搭配新配饰时,它都会告诉你,看起来怎么样。

所以,这个onInstalled事件能帮你搞定这几件事:
● 设定基本配置,比如创建存储数据的房间。
● 迁移旧数据,如果插件更新了,得把旧衣服换成新的。
● 给用户展示最新的通知或引导页面,尤其是当你加入了一些新花样时。

当用户装上了你的扩展,然后你又推出新版本,onInstalled事件再次唱歌,你可以在这个时候加点逻辑来处理更新的剧本。对于用户来说,这就确保了不管是第一次装扩展还是更新,应用都能像模像样地运作。

popup.html:

虽然这章我们不会深挖popup.html,但你得创建个简洁的文件,让manifest.json里的声明不会空话:

<!DOCTYPE html>
<html>
<head><title>智能笔记</title><style>/* 这里可以穿点漂亮的衣服 */</style>
</head>
<body><h1>智能笔记</h1><!-- 这里会展示用户的小秘密笔记和一些神秘按钮 -->
</body>
</html>

icon.png:

别忘了准备一个icon.png图标文件,放在你的插件根目录里,给它一个家。

测试:

干完这些活儿,你的插件就应该能正常装上了,并且在安装或更新的时候在控制台里唱歌。别忘了去Chrome的扩展页面(chrome://extensions/)装上你的插件,并且开启开发者模式来试试。

就像下面这图一样:

当你打开浏览器的调试模式控制台,重新安装Chrome插件,你会看到一段日志唱歌给你听。

这就是第2章的全部精彩内容啦,通过这一章,你已经把后台脚本学废了,并为下一章的高级功能做好了准备。下回我们继续搞“智能笔记”插件的其他花样,别错过哟!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/704219.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数学建模【GM(1, 1)灰色预测】

一、GM(1, 1)灰色预测简介 乍一看&#xff0c;这个名字好奇怪&#xff0c;其实是有含义的 G&#xff1a;Grey&#xff08;灰色&#xff09;M&#xff1a;Model&#xff08;模型&#xff09;(1, 1)&#xff1a;只含有一个变量的一阶微分方程模型 提到灰色&#xff0c;就得先说…

大数据开发项目--音乐排行榜

环境&#xff1a;windows10&#xff0c;centos7.9&#xff0c;hadoop3.2、hbase2.5.3和zookeeper3.8完全分布式&#xff1b; 环境搭建具体操作请参考以下文章&#xff1a; CentOS7 Hadoop3.X完全分布式环境搭建 Hadoop3.x完全分布式环境搭建Zookeeper和Hbase 1. 集成MapReduce…

消息中间件之RocketMQ源码分析(十八)

Broker CommitLog索引机制中的构建过程 1.创建ConsumeQueue和IndexFile。 ConsumeQueue和IndexFile两个索引都是由ReputMessageService类创建的 RequestMessageService类图 ReputMessageService服务启动后的执行过程。 doReput()方法用于创建索引的入口&#xff0c;通常通过…

运用工具Postman快速导出python接口测试脚本

Postman的脚本可以导出多种语言的脚本&#xff0c;方便二次维护开发。 Python的requests库&#xff0c;支持python2和python3&#xff0c;用于发送http/https请求 使用unittest进行接口自动化测试 一、环境准备 1、安装python&#xff08;使用python2或3都可以&#xff09;…

【数据结构与算法】常用算法 前缀和

&#x1f389;&#x1f389;欢迎光临&#x1f389;&#x1f389; &#x1f3c5;我是苏泽&#xff0c;一位对技术充满热情的探索者和分享者。&#x1f680;&#x1f680; &#x1f31f;特别推荐给大家我的最新专栏《数据结构与算法&#xff1a;初学者入门指南》&#x1f4d8;&am…

离散数学——树思维导图

离散数学——树思维导图 文章目录 前言内容大纲参考 前言 这是当初学习离散数学时整理的笔记大纲&#xff0c;其中包含了自己对于一些知识点的体悟。现将其放在这里作为备份&#xff0c;也希望能够对你有所帮助。 当初记录这些笔记只是为了在复习时更快地找到对应的知识点。…

Python爬虫之极验滑动验证码的识别

极验滑动验证码的识别 上节我们了解了可以直接利用 tesserocr 来识别简单的图形验证码。近几年出现了一些新型验证码&#xff0c;其中比较有代表性的就是极验验证码&#xff0c;它需要拖动拼合滑块才可以完成验证&#xff0c;相对图形验证码来说识别难度上升了几个等级。本节将…

如何在Linux部署Portainer并结合内网穿透远程管理本地Docker容器

文章目录 前言1. 部署Portainer2. 本地访问Portainer3. Linux 安装cpolar4. 配置Portainer 公网访问地址5. 公网远程访问Portainer6. 固定Portainer公网地址 前言 Portainer 是一个轻量级的容器管理工具&#xff0c;可以通过 Web 界面对 Docker 容器进行管理和监控。它提供了可…

用c# 自己封装的Modbus工具类库源码

前言 Modbus通讯协议在工控行业的应用是很多的&#xff0c;并且也是上位机开发的基本技能之一。相关的类库也很多也很好用。以前只负责用&#xff0c;对其并没有深入学习和了解。前段时间有点空就在这块挖了挖。想做到知其然还要知其所以然。所以就有了自己封装的Modbus工具类库…

Mysql 常用数据类型

数值型(整数)的基本使用 如何定义一个无符号的整数 数值型(bit)的使用 数值型(小数)的基本使用 字符串的基本使用 字符串使用细节 日期类型的基本使用

Orange3数据预处理(列选择组件)数据角色及类型描述

在Orange3的文件组件中&#xff0c;datetime、categorical、numeric以及text代表不同种类的数据类型&#xff0c;具体如下&#xff1a; datetime&#xff1a;代表日期和时间类型的数据。通常用于时间序列分析、生存分析和其他需要考虑时间因素的机器学习任务中。例如&#xff0…

图像读取裁剪与人脸识别

图像读取 Image read ⇒ \Rightarrow ⇒ torchvision.datasets from torchvision import datasets dataset datasets.ImageFolder(data_dir, transformtransforms.Resize((512, 512)))Return value illustration dataset[0][0]是PIL.Image objects&#xff0c;这利用IPyth…

小红书关键词爬虫

标题 1 统计要收集的关键词,制作一个文件夹2 爬取每一页的内容3 爬取标题和内容4 如果内容可以被查看,爬取评论内容5 将结果进行汇总,并且每个帖子保存为一个json文件,具体内容6 总结1 统计要收集的关键词,制作一个文件夹 例如,我要收集旅游相关的,就收集: 旅游、旅行…

关系型数据库事务的四性ACID:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability)

关系型数据库事务的四性ACID:原子性&#xff08;Atomicity&#xff09;、一致性&#xff08;Consistency&#xff09;、隔离性&#xff08;Isolation&#xff09;和持久性&#xff08;Durability&#xff09; 事务的四性通常指的是数据库事务的ACID属性&#xff0c;包括原子性&…

Python从入门到精通指南【第101篇—入门到精通】【文末送书-24】

文章目录 Python从入门到精通指南第一步&#xff1a;入门基础1.1 安装Python1.2 Hello World1.3 变量和数据类型1.4 控制流程 第二步&#xff1a;深入学习2.1 函数和模块2.2 列表、元组和字典2.3 文件操作 第三步&#xff1a;高级主题3.1 面向对象编程3.2 异常处理3.3 正则表达…

大型电商日志离线分析系统(一)

一、项目需求分析 某大型网站日志离线分析系统 1.1 概述 该部分的主要目标就是描述本次项目最终七个分析模块的页面展示。 1.2 工作流 在我们的demo展示中&#xff0c;我们使用jqueryecharts的方式调用程序后台提供的rest api接口&#xff0c;获取json数据&#xff0c;然后…

《极简C++学习专栏》之结束语

朋友们&#xff0c;经过这么长的时间&#xff0c;《极简C学习专栏》的文章创作就要结束了&#xff0c;感谢你们一路陪伴&#xff01; 也希望你们能支持我接下来的其他专栏的创作&#xff01; 专栏的初衷 《极简C学习》专栏的初衷源自于我个人的学习笔记&#xff0c;记录下自己…

网络安全与信创产业发展:构建数字时代的护城河

✨✨ 欢迎大家来访Srlua的博文&#xff08;づ&#xffe3;3&#xffe3;&#xff09;づ╭❤&#xff5e;✨✨ &#x1f31f;&#x1f31f; 欢迎各位亲爱的读者&#xff0c;感谢你们抽出宝贵的时间来阅读我的文章。 我是Srlua&#xff0c;在这里我会分享我的知识和经验。&#x…

数字人的未来:数字人对话系统 Linly-Talker + 克隆语音 GPT-SoVITS

&#x1f680;数字人的未来&#xff1a;数字人对话系统 Linly-Talker 克隆语音 GPT-SoVITS https://github.com/Kedreamix/Linly-Talker 2023.12 更新 &#x1f4c6; 用户可以上传任意图片进行对话 2024.01 更新 &#x1f4c6; 令人兴奋的消息&#xff01;我现在已经将强…

Vue | (六)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程

文章目录 &#x1f4da;Vue 中的自定义事件&#x1f407;使用方法&#x1f407;案例练习&#x1f407;TodoList案例优化 &#x1f4da;全局事件总线&#x1f407;使用方法&#x1f407;案例练习&#x1f407;TodoList案例优化 &#x1f4da;消息订阅与发布&#x1f407;使用方法…