利用Vue 脚手架 开发chrome 插件,太方便了!

前言

一个 Chrome 插件,核心就是 manifest.json 文件,manifest.json 下的属性

  • content_scripts 指定inject的脚本列表 js,css    【 injected】

  • browser_action 中 default_popup指定popup弹出的html文件路径 【popup】

  • background     后台常驻页面 【background】

用户通过 popup 页面操作,inject 分析 DOM ,与 background 通信将数据传给 background 汇总,这个通信是很麻烦的。

vue开发 Chrome 插件优势

避免复杂的通信

原生的文件开发插件,需要使用 

chrome.runtime.sendMessage({action:ACTION.START_FETCH,data:xxxx})来传递数据,就那么一两个还是可以的,但是往往我们要做的插件不能是这么简单的。通信多了就麻烦了,vue 就可以解决这个问题,不需要麻烦的通信。

 ▍DOM操作

开发插件不免不了用户交互,原生的 DOM 操作,document.getElementById() 这样来操作是麻烦的,vue 的双向绑定完美的决绝这个问题。

▎打包

vue 和 webpack实时打包 方便

vue初始化项目

前提是你已经安装了脚手架环境,这里不再演示

vue create hello-chrome-vue

这里默认选中的是vue2.0语法 

Please pick a preset: Default ([Vue 2] babel, eslint)
✨ Creating project in E:\dev_workspace\webstorm_workspace\hello-chrome-vue.
🗃 Initializing git repository...
⚙️ Installing CLI plugins. This might take a while...


> yorkie@2.0.0 install E:\dev_workspace\webstorm_workspace\hello-chrome-vue\node_modules\yorkie
> node bin/install.js

setting up Git hooks
done


> core-js@3.19.3 postinstall E:\dev_workspace\webstorm_workspace\hello-chrome-vue\node_modules\core-js
> node -e "try{require('./postinstall')}catch(e){}"


> ejs@2.7.4 postinstall E:\dev_workspace\webstorm_workspace\hello-chrome-vue\node_modules\ejs
> node ./postinstall.js

added 1264 packages from 656 contributors in 52.131s

84 packages are looking for funding
  run `npm fund` for details

🚀 Invoking generators...
📦 Installing additional dependencies...

added 53 packages from 36 contributors in 19.491s

89 packages are looking for funding
  run `npm fund` for details

⚓ Running completion hooks...

📄 Generating README.md...

🎉 Successfully created project hello-chrome-vue.
👉 Get started with the following commands:

 $ cd hello-chrome-vue
 $ npm run serve

 WARN Skipped git commit due to missing username and email in git config, or failed to sign commit.You will need to perform the initial commit yourself.

Successfully 代表安装成功 

删除不需要的文件

由于我们不做完全的web 项目,vue-cli3 脚手架生成的文件,我们不是都需要, 这里就删除不必要的部分

src/main.js

src/components

src/App.vue (可选) 

 

安装chrome-ext插件依赖

我们需要修改项目使得 它适用于开发 Chrome 扩展只能使用 vue add chrome-ext  命令来安装,如果使用 yarn add chrome-ext 会发现项目没有任何改变。

安装完之后,package.json 的配置如下

chrome-ext依赖安装对应的就是 vue-cli-plugin-chrome-ext ,整个项目目录如下:

vue.config.js 自动生成配置,backgroud.js 是我后配置的

const CopyWebpackPlugin = require("copy-webpack-plugin");
const path = require("path");

// Generate pages object
const pagesObj = {};

const chromeName = ["popup", "options"];

chromeName.forEach(name => {
  pagesObj[name] = {
    entry: `src/${name}/index.js`,
    template: "public/index.html",
    filename: `${name}.html`
  };
});
const background = {
    from: path.resolve("src/background.js"),
    to: `${path.resolve("dist")}/background.js`
}
const plugins =
  process.env.NODE_ENV === "production"
    ? [
          {
              from: path.resolve("src/manifest.production.json"),
              to: `${path.resolve("dist")}/manifest.json`
          },
          {
              ...background
          }
      ]
    : [
        {
          from: path.resolve("src/manifest.development.json"),
          to: `${path.resolve("dist")}/manifest.json`
        },
          {
              ...background
          }
      ];

module.exports = {
  pages: pagesObj,
  configureWebpack: {
    plugins: [CopyWebpackPlugin(plugins)]
  }};

package.json 配置运行脚本

"scripts": {
    "serve": "vue-cli-service serve",
    "build": "vue-cli-service build",
    "build:dev": "vue-cli-service build --mode development",
    "lint": "vue-cli-service lint",
    "build-watch": "vue-cli-service build-watch"  },

插件使用

npm run build 会生成一个dist, 此文件夹可以直接放到Google浏览器中就行安装

popup 里的目录结构是安装chrome-ext插件后,自动生成的

App.vue里的内容是我自己随便定义的

<template>
    <div class="main_app">
        <button id="changeColor" @click="handleClick">测试</button>
        <input type="text" v-model="value">
    </div>
</template>

<script>
    import chrome from "vue-cli-plugin-chrome-ext";

    export default {
        name: 'app',
        data(){
            return{
              listenerId: null,
              value:'',
            }
        },
        mounted() {
            let that = this;
            this.$nextTick(()=>{
                // When the button is clicked, inject setPageBackgroundColor into current page
                that.listenerId = that.$refs.changeColor.addEventListener("click", async () => {
                    let [tab] = await chrome.tabs.query({active: true, currentWindow: true});
                    chrome.scripting.executeScript({
                        target: {tabId: tab.id},
                        function: that.setPageBackgroundColor,
                    });
                });

            })

        },
        destroyed() {
            this.listenerId && window.removeEventListener(this.listenerId);
        },
        methods: {
            handleClick() {
                this.value = new Date().getMilliseconds();
                chrome.storage.sync.get("color", ({color}) => {
                    this.$refs.changeColor.style.backgroundColor = color;
                });
            },
            setPageBackgroundColor() {
                console.log('setPageBackgroundColor---');
                chrome.storage.sync.get("color", ({color}) => {
                    document.body.style.backgroundColor = color;
                });
            }
        }
    }
</script>

<style>

    button {
        height: 50px;
        width: 50px;
        outline: none;
        margin: 10px;
        border: none;
        border-radius: 2px;
    }

    button.current {
        box-shadow: 0 0 0 2px white,
        0 0 0 4px black;
    }
</style>

这里使用到了 相关的chrome api 需要引入 “@type/chrome” 增加chrome类型声明

npm install --save-d @types/chrome

记得关闭 eslint 语法检测 方便开发

 

在调试过程中,如果想要打印插件内的日志 ,需要右键点击插件图标单独的点击审核元素,否则直接按F12浏览器 是捕获不到的

最后

项目按照上面的流程走完之后,以后的页面就完全按照Vue的方式开发即可,引入一些好的UI,确实比直接写JS和jquery.js快很多的

点击下方卡片/微信搜索,关注公众号“天宇文创意乐派”(ID:gh_cc865e4c536b)

听说点赞和关注本号的都找到漂亮的小姐姐了哟且年后必入百万呀!!

往期推荐

紧急!Log4j 史诗级漏洞来袭,请速速自查!

TGA 2021:《绝地求生》2022年1月12日开始免费

惊呆了!网传腾讯《英雄联盟》项目组年终奖每人120万!

使用 StopWatch 优雅打印执行耗时

雷军做程序员时写的文章,挺有哲学的!

SpringBoot + Netty4 实现自己RPC

本文使用 文章同步助手 同步

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,530评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,403评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,120评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,770评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,758评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,649评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,021评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,675评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,931评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,751评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,410评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,004评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,969评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,042评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,493评论 2 343

推荐阅读更多精彩内容