2022-06-16

谷歌插件

什么是谷歌插件呻引?

谷歌插件,全名谷歌瀏覽器擴(kuò)展程序。那什么是谷歌瀏覽器擴(kuò)展程序靠瞎,官方說明如下:

擴(kuò)展程序允許您為 Chrome瀏覽器增加功能,而不需要深入研究本機(jī)代碼求妹。您可以使用您在網(wǎng)頁開發(fā)中已經(jīng)很熟悉的核心技術(shù)(HTML乏盐、CSS 與 JavaScript)為 Chrome 瀏覽器創(chuàng)建新的擴(kuò)展程序。

擴(kuò)展是 Web 平臺中使用的HTML制恍、CSS父能、JavaScript、圖像和其他文件的壓縮包净神『瘟撸可以修改用戶瀏覽并與之交互中的web內(nèi)容,它們還可以擴(kuò)展和更改瀏覽器本身的行為鹃唯。

配置文件

谷歌插件的核心文件就是配置文件—manifest.json(清單)文件爱榕。其中,manifest.json 文件最基本的 Api 如下:

{
    "name": "chrome extension",
    "version": "1.0.0",
    "manifest_version": 2,
    "description": "A litlle chrome extension demo"
}

主要是包含所寫谷歌插件的名稱坡慌,版本黔酥,以及相關(guān)描述。manifest.json作為谷歌插件的核心部分,個人認(rèn)為該文件對插件來說就相當(dāng)于一個入口配置文件跪者,開發(fā)只需要在這個文件通過配置相應(yīng)的 js棵帽,調(diào)用谷歌瀏覽器提供的Api,來達(dá)到完善這個插件的目的坑夯。
官網(wǎng)詳細(xì)配置鏈接

基本Api使用

google官方提供的Api比較多岖寞,google文檔也做了歸類,大致分為哪些行為操作柜蜈,我們可以根據(jù)行為需求操作去找相應(yīng)的api去做探索與實(shí)踐仗谆。

在清單文件中還有很多 Api 就不一一列舉了,下面只介紹幾個個人認(rèn)為比較重要的幾個 Api淑履,通過以下幾個 Api 可以使得開發(fā)同學(xué)對于谷歌插件的開發(fā)過程有一個大概的認(rèn)識隶垮。

  • browser_action
{
    ...

    "browser_action": {
        "default_icon": {
          "16": "1.png",
          "32": "1.png"
        },
        "default_title": "demo extension",
        "default_popup": "popup.html"
    },

    ...
}

browser_action 可設(shè)置瀏覽器右上角的圖標(biāo),名稱秘噪。default_popup 可配置點(diǎn)擊圖標(biāo)后會出現(xiàn)的一個小窗口狸吞,這里可以做一些臨時(shí)性的操作。

  • permissions
{
    ...

    "permissions": [ "activeTab", "storage", "tabs", "contextMenus" ],
    
    ...
}

permissions 可配置谷歌插件權(quán)限申請指煎,如 contextMenus(右鍵菜單), tabs(標(biāo)簽)蹋偏,storage(插件本地存儲)。

  • content_scripts
{
    ...

    "content_scripts": {
        "matches": ["<all_urls>"],
        "css": ["/content.css"],
        "js": ["content.js"]
    },
    
    ...
}

content-scripts至壤,其實(shí)就是谷歌插件中向頁面注入腳本的一種形式(雖然名為 script威始,其實(shí)還可以包括 CSS 的),借助 content-scripts 可以實(shí)現(xiàn)通過配置的方式輕松向指定頁面注入 JS 和 CSS像街。官方解釋:

內(nèi)容腳本允許擴(kuò)展將邏輯注入頁面以讀取和修改其內(nèi)容黎棠。內(nèi)容腳本包含在已加載到瀏覽器中的頁面上下文中執(zhí)行的 JavaScript。

  • background
{
    ···

    "background": {
        "scripts": ["background.js"],
        "persistent": false
    },

    ···
}

background一直駐留在瀏覽器后臺的頁面可以時(shí)刻監(jiān)聽瀏覽器的各種行為镰绎。它是一個常駐的頁面脓斩,它的生命周期是插件中所有類型頁面中最長的,它隨著瀏覽器的打開而打開畴栖,隨著瀏覽器的關(guān)閉而關(guān)閉随静,所以通常把需要一直運(yùn)行的、啟動就運(yùn)行的吗讶、全局的代碼放在 background 里面挪挤。

以上,是一些谷歌插件清單文件基本且比較重要的一些 Api关翎。

腳本通信

插件各個模塊下的 js 文件是可以相互通信的扛门,分別是屬于background字段的background.js,content.js纵寝,以及popup.html的js文件popup.js论寨。這三個js文件通過谷歌插件提供的信息交互機(jī)制進(jìn)行通信星立,彼此傳遞信息。

==content.js== 可以訪問當(dāng)前頁面葬凳,但是可能訪問的API受到限制绰垂。例如,它無法偵聽瀏覽器操作的點(diǎn)擊火焰。

==background.js== 該腳本可以訪問每個Chrome API劲装,但無法訪問當(dāng)前頁面。

那么background和content該如何通信呢昌简?

// content 發(fā)出消息
chrome.runtime.sendMessage({ greeting: "content send" }, function (response) {
  console.log("content get response", response);
});
// content 監(jiān)聽消息
chrome.extension.onMessage.addListener((request, sender, sendResponse) => {
  sendResponse({ content: "content get" });
});
// background 監(jiān)聽消息
chrome.runtime.onMessage.addListener(function (request, sender, sendResponse) {
  sendResponse({ content: "background get" });

  // background 發(fā)送消息
  chrome.tabs.query({ active: true, currentWindow: true }, function (tabs) {
    const msg = "background send";
    chrome.tabs.sendMessage(tabs[0].id, msg, function (response) {
      console.log("background get response", response);
    });
  });
});

擴(kuò)展程序及其內(nèi)容腳本之間的通信通過使用消息傳遞進(jìn)行占业。任何一方都可以偵聽從另一端發(fā)送的消息,并在同一通道上響應(yīng)纯赎。chrome提供了簡單請求和長期鏈接谦疾。

經(jīng)過這幾天的了解,我們要使用插件更高級的功能犬金,還是需要了解各個 api 的能力念恍,需要大量的google搜索!

本次分享就基于簡單的分享對谷歌插件的基本知識,敬請下次繼續(xù)分享~

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末晚顷,一起剝皮案震驚了整個濱河市峰伙,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌该默,老刑警劉巖瞳氓,帶你破解...
    沈念sama閱讀 217,907評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異权均,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)锅锨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評論 3 395
  • 文/潘曉璐 我一進(jìn)店門叽赊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人必搞,你說我怎么就攤上這事必指。” “怎么了恕洲?”我有些...
    開封第一講書人閱讀 164,298評論 0 354
  • 文/不壞的土叔 我叫張陵塔橡,是天一觀的道長。 經(jīng)常有香客問我霜第,道長葛家,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,586評論 1 293
  • 正文 為了忘掉前任泌类,我火速辦了婚禮癞谒,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己弹砚,他們只是感情好双仍,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,633評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著桌吃,像睡著了一般朱沃。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上茅诱,一...
    開封第一講書人閱讀 51,488評論 1 302
  • 那天逗物,我揣著相機(jī)與錄音,去河邊找鬼让簿。 笑死敬察,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的尔当。 我是一名探鬼主播莲祸,決...
    沈念sama閱讀 40,275評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼椭迎!你這毒婦竟也來了锐帜?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,176評論 0 276
  • 序言:老撾萬榮一對情侶失蹤畜号,失蹤者是張志新(化名)和其女友劉穎缴阎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體简软,經(jīng)...
    沈念sama閱讀 45,619評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蛮拔,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,819評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了痹升。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片建炫。...
    茶點(diǎn)故事閱讀 39,932評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖疼蛾,靈堂內(nèi)的尸體忽然破棺而出肛跌,到底是詐尸還是另有隱情,我是刑警寧澤察郁,帶...
    沈念sama閱讀 35,655評論 5 346
  • 正文 年R本政府宣布衍慎,位于F島的核電站,受9級特大地震影響皮钠,放射性物質(zhì)發(fā)生泄漏稳捆。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,265評論 3 329
  • 文/蒙蒙 一麦轰、第九天 我趴在偏房一處隱蔽的房頂上張望眷柔。 院中可真熱鬧期虾,春花似錦、人聲如沸驯嘱。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,871評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽鞠评。三九已至茂蚓,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間剃幌,已是汗流浹背聋涨。 一陣腳步聲響...
    開封第一講書人閱讀 32,994評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留负乡,地道東北人牍白。 一個月前我還...
    沈念sama閱讀 48,095評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像抖棘,于是被迫代替她去往敵國和親茂腥。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,884評論 2 354