当前位置: 首页 > news >正文

【chrome扩展开发】如何在项目中判断插件是否已安装

由于安全限制,本文采取间接的方式实现

1、项目部分

比如通过cookie、localStorage等进行状态存储

1.1、初始化判断

function getCookie(name){let arr = document.cookie.match(new RegExp("(^| )"+name+"=([^;]*)(;|$)"))if(arr != null){return unescape(arr[2])}else{return null}
}let _isChromePluginInstall = getCookie('chrome-plugin');
if(_isChromePluginInstall && _isChromePluginInstall==='Y'){// 已安装插件
}else{// 未安装插件
}

1.2、卸载状态变更

function getQueryString(name) {var reg = new RegExp('(^|&)' + name + '=([^&]*)(&|$)', 'i');var r = window.location.search.substr(1).match(reg);if (r != null) {return unescape(r[2]);}return null;
}let _on = getQueryString('on')
if(_on && _on === 'uninstalled'){// 修改插件安装状态// 其他业务处理
}

2、Chrome Extensions部分

background.js中进行安装、卸载事件监听

2.1、安装事件监听

/*** 首次安装扩展程序、扩展程序更新到新版本以及 Chrome 更新到新版本时触发* @link https://developer.chrome.com/docs/extensions/reference/runtime/#event-onInstalled*/
chrome.runtime.onInstalled.addListener(function () {setTimeout(function () {// 对目标项目进行cookie写入const _cf = {name: 'chrome-plugin',value: 'Y',url: 'http://xxxx.xxx',domain: 'xxxx.xxx'}chrome.cookies.set(_cf, function (res) {// ...});}, 1000)})

2.2、卸载事件监听

/*** 转跳至目标项目地址进行状态变更、统计等事务处理* @link https://developer.chrome.com/docs/extensions/reference/runtime/#method-setUninstallURL*/
chrome.runtime.setUninstallURL(`${SysConfig.APP_URL}/#?on=uninstalled`, ()=>{})

Ps:
management权限的监听事件,似乎无法对安装、卸载起到作用,具体原因不清楚,还有待研究。
有兴趣的小伙伴也可以研究研究,官方文档地址:https://developer.chrome.com/docs/extensions/reference/management/

http://www.lryc.cn/news/144535.html

相关文章:

  • Centos 7.6 安装mongodb
  • Ubuntu下安装nginx服务,实现通过URL读取ubuntu下图片
  • 本地部署 Stable Diffusion(Mac 系统)
  • 浪潮云海护航省联社金融上云,“一云多芯”赋能数字农业
  • MyCat的XA事务研究及字符集问题
  • 9、监测数据采集物联网应用开发步骤(7)
  • 微信小程序开发教学系列(9)- 小程序页面优化
  • 如何将储存在Mac或PC端的PDF文件传输到移动设备呢?
  • 一图看懂架构划分原则:技术划分 OR 领域划分?
  • 从零开始的Hadoop学习(二)| Hadoop介绍、优势、组成、HDFS架构
  • 问道管理:逾4600股飘红!汽车板块爆了,多股冲击涨停!
  • Java 语言实现选择排序算法
  • 【C语言每日一题】05. 输出保留12位小数的浮点数
  • 科大讯飞永久免费GPT入口来了!!!
  • 亚马逊反馈和评论的区别
  • Linux 查看当前文件夹下的文件大小
  • 玩转 PI 系列-看起来像服务器的 ARM 开发板矩阵-Firefly Cluster Server
  • 《Flink学习笔记》——第六章 Flink的时间和窗口
  • nano主板扩大swap交换交换空间大小 /windows里远程传输文件/ssh远程登陆访问GUI界面报错
  • 7个用于机器学习和数据科学的基本 Python 库
  • Kafka 简介 + 学习笔记
  • Mybatis小记
  • 如何向BertModel增加字符
  • copilot切换下一条提示的快捷键
  • Mongodb 删除文档Delete与Remove的区别
  • Docker 的基本概念和优势
  • 基于 xhr 实现 axios
  • 基于面向对象的大模型代码生成
  • 易云维®FMCS厂务系统创造工厂全新的“数字低碳智能”应用场景
  • 【Linux应用部署篇】在CSDN云IDE平台部署Etherpad文档编辑器