使用Angular构建Chrome插件

最近公司有业务需求需要做一个Chrome插件,原本想着用jQuery + Bootstarp搞定。但是由于已经使用Angular已经太久了,重新再用jQuery有点蛋疼。后面查了一下资料,发现有人用React写过Chrome插件。仔细看了下,觉得实际上应该是一样的原理。尝试了一下Angular + Material,果然可以,过程如下:

1.先贴配置

Angular CLI: 7.1.3
Angular: 7.1.3
Node: 10.11.0
Material UI: 7.2.1

配置理论上不需要跟我一样,我贴出来的原因是方便有个参考而已。Angular 4以上的版本应该都是可以通用的。

image.png

2.Angular项目打包编译

没有项目的话用CLI新建一个
ng new OneAngularProject

已有项目的直接在项目下build
ng build

注意,build时不用任何参数,以往我们为了压缩合并js,css等文件会添加参数,以保证build出来的是最小版本。但如果是构建Chrome插件的话,就不能加参数了。

3.编辑manifest.json

我项目里的mainfest.json如下

{
    "manifest_version": 2,
    "name": "Angular Chrome Extension",
    "description": "Miner app as chrome extension using angular7",
    "version": "1.0",
    "browser_action": {
        "default_icon": "favicon.ico",
        "default_popup": "index.html"
    },
    "permissions": [],
    "content_security_policy": "script-src 'self' 'unsafe-eval'; object-src 'self'",
    "web_accessible_resources": [
        "assets/css/*",
        "assets/js/*",
        "assets/fonts/*"
    ]
}

"content_security_policy": "script-src 'self' 'unsafe-eval'; object-src 'self'" 注意这句一定要加上,不加上的话会报错

web_accessible_resources 字段看自己项目里的业务需求请自定义

4.将build好的文件放入manifest.json所在文件夹下

image.png

在Chrome浏览器中加载该插件即可,记得要打开开发者模式

image.png

效果如图:


效果.gif

具体如何开发Chrome插件和一些细节,这里就不提了。

有兴趣的可以看这个博客里的文章,个人觉得写得还是很不错的。

chrome插件开发教程

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1 Webpack 1.1 概念简介 1.1.1 WebPack是什么 1、一个打包工具 2、一个模块加载工具 3...
    Kevin_Junbaozi阅读 11,766评论 0 16
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 27,981评论 1 45
  • $HTML, HTTP,web综合问题 1、前端需要注意哪些SEO 2、 的title和alt有什么区别 3、HT...
    Hebborn_hb阅读 10,090评论 0 20
  • 第三十六天修改则:迎春2 惊蛰已过,几朵淡黄色迎春花舒展身姿,悄然攀上了有些干枯,却冒着嫩绿新芽的枝条。迎春形态各...
    April2005阅读 50评论 0 0
  • 这几天听怎样度过孩子的青春期这堂课现总结如下: 老师在课的前一部分咨询家庭状况,首先我感觉明显的是面对孩子的现状非...
    兔子的幸福生活阅读 1,482评论 1 6