Chrome扩展插件案例:单词查询

Chrome扩展插件案例:单词查询

在页面内选中单词,右键菜单中显示词典连接,自动将选中单词发送至该词典查询

创建项目文件夹,在文件夹内创建一下文件

manifest.json:

javascript 复制代码
{
    "manifest_version":2,//版本号,由google指定的manifest格式版本为2
    "name": "有道词典查询(第三方)",//插件名称
    "version":"1.0",//插件版本
    "description":"在网页内选中任意单词后,用鼠标右键菜单查询",//插件描述
    "icons":{
        "128":"img/icon.png",
        "48":"img/icon.png",
        "16":"img/icon.png"
    },
    "browser_action":{
        "default_icon":"img/icon.png",
        "default_popup":"popup.html"
    },
    "background":{
        "scripts":["background.js"],//关联的代码
        "persistent":true //在页面上一直运行
    },
    "permissions":[       
        "contextMenus"
    ]
    
}
 

popup.html:

html 复制代码
<!DOCTYPE html>
<html>
<head>
	<meta charset="utf-8">
    <title>有道词典查询</title>
</head>
<body>
	<!--点击浏览器插件图标时会弹出的内容-->
    <h1 style="color:red;width:200px;">有道词典查询</h1>
	<p>在页面选中单词后,鼠标右键菜单中选择"有道词典查询"</p>
</body>
</html>

background.js

javascript 复制代码
chrome.contextMenus.create({
	id:"YoudaoDictionarySearch",
	title: '有道英汉词典查询:%s', // %s表示选中的文字
	contexts: ['selection'], // 只有选中页面内文字时才会出现此右键菜单
	onclick: function(params)    {
		//创建新的标签页
		chrome.tabs.create({url: 'https://www.youdao.com/result?lang=en&word=' + encodeURI(params.selectionText)});
	}
});

然后在Chrome浏览器中地址栏右边 -> 拓展程序 -> 管理拓展程序 -> 打开"开发者模式" -> 加载已解压的扩展程序 -> 大功告成!

相关推荐
骄马之死1 小时前
SpringMVC + SpringBoot 核心知识点总结
java·spring boot·后端
sbjdhjd1 小时前
Redis 主从复制、哨兵高可用与 Cluster 集群部署实验手册
运维·前端·redis·云原生·开源·bootstrap·html
乐兮创想 小林1 小时前
企业官网移动端性能优化实战:从 Core Web Vitals 到图片/CDN/响应式的工程清单
前端·性能优化·网站建设·北京网站建设公司
前端一小卒2 小时前
不手写代码的第 30 天,我才明白前端这个岗位还剩什么
前端·javascript·ai编程
Ajie'Blog2 小时前
Copilot Agent Tasks API 开放:AI 编程开始进入后台任务时代
服务器·前端·javascript·人工智能·copilot·ai编程
郑洁文2 小时前
基于Spring Boot的流浪动物救助网站
java·spring boot·后端·毕设·流浪动物救助
老毛肚2 小时前
jeecgboot vue TS & 模板化 04
前端·javascript·vue.js
螺丝钉code3 小时前
JAVA项目 Claude code CLAUDE.md 到底应该怎么写
java·人工智能·claude code
AI_零食4 小时前
鸿蒙PC Electron跨平台应用开发:24时区时间表应用详解
前端·华为·electron·开源·harmonyos·鸿蒙
摇滚侠4 小时前
Maven 入门+高深 单一架构案例 54-59
java·架构·maven·intellij-idea