1987WEB视界-分享互联网热门产品和行业

您现在的位置是:首页 > 网络工具 > 正文

网络工具

开发一个简单chrome浏览器插件

1987web2023-10-21网络工具138
chrome之所以越来越好用,很大一部分原因归功于功能丰富的插件;对于chrome忠实用户来说,了解和开发一款适合自己的chrome插件,确实是一件很cool的事情。

chrome 之所以越来越好用,很大一部分原因归功于功能丰富的插件;对于chrome忠实用户来说,了解和开发一款适合自己的chrome插件,确实是一件很cool的事情。

了解 chrome 插件

chrome 插件个人理解:就是一个html + js +css + image的一个web应用;不同于普通的web应用,chrome插件除了兼容普通的js,json,h5等api,还可以调用一些浏览器级别的api,例如收藏夹,历史记录等。

推荐两个网站了解和入门

  • 谷歌官方 API:https://developer.chrome.com/extensions/getstarted

  • 360 的文档:http://open.chrome.360.cn/extension_dev/overview.html

开始写第一个插件

1)文件结构

一个简单的 demo,文件目录如下和普通的 web 文件没有什么区别,简单介绍下:

  • html:存放 html 页面

  • js:存放 js

  • locales:存放了一个多语言的兼容【可无】

  • image:放了两张图片【初期图标】

  • manifest:核心入口文件

2)写一个 manifest

api 参考文档:http://open.chrome.360.cn/extension_dev/manifest.html

直接上代码:

{
  "name": "hijack analyse plug",
  "version": "0.0.1",
  "manifest_version": 2,

  // 简单描述
  "description": "chrome plug analyse and guard the http hijack",
  "icons": {
    "16": "image/icon16.png",
    "48": "image/icon48.png"
  },
  // 选择默认语言
  "default_locale": "en",

  // 浏览器小图表部分
  "browser_action": {
    "default_title": "反劫持",
    "default_icon": "image/icon16.png",
    "default_popup": "html/test.html"
  },

  // 引入一个脚本
  "content_scripts": [
    {
      "js": ["script/test.js"],
      // 在什么情况下使用该脚本
      "matches": [
        "http://*/*",
        "https://*/*"
      ],
      // 什么情况下运行【文档加载开始】
      "run_at": "document_start"
    }
  ],
  // 应用协议页面
  "permissions": [
    "http://*/*",
    "https://*/*"
  ]
}

test.js 文件

/**
 * @author: cuixiaohuan
 * Date: 16/4/13
 * Time: 下午8:41
 */
(function(){
    /**
     * just test for run by self
     */
    console.log(begin);
})();

test.html 文件




    
    just for test


test

3)运行插件

chrome 中输入:chrome://extensions

选择加载已解压的插件-》选择文件根目录即可。

效果如下:

一个基本的插件变完成了,勾选已启用,随便打开一个网页,会看到 log 中输出如下

点击页面上面的小图标如下图:

优化建议

一个小的插件已经完成,但是还有更多的 api 和有趣的事情可以去做。下面是 360 文档中给出一些优化建议,共勉。

  • 确认 Browser actions 只使用在大多数网站都有功能需求的场景下。确认 Browser actions 没有使用在少数网页才有功能的场景, 此场景请使用page actions。

  • 确认你的图标尺寸尽量占满 19x19 的像素空间。 Browser action 的图标应该看起来比 page action 的图标更大更重。

  • 尽量使用 alpha 通道并且柔滑你的图标边缘,因为很多用户使用 themes,你的图标应该在在各种背景下都表现不错。不要不停的闪动你的图标,这很惹人反感。

阅读原文如果你也觉着这是件挺 cool 的事儿,那么就动手撸一个 chrome 插件吧。