成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

實現(xiàn)一個簡單的chrome插件

rubyshen / 1208人閱讀

摘要:小結(jié)本文只是簡單分享了如何開發(fā)一個簡單的谷歌瀏覽器插件,以及一些注意事項,并且提到了如何授權(quán)和使用谷歌插件,重點介紹了插件開發(fā)必備的入口文件和插件中幾個重要環(huán)境以及環(huán)境之間的通信。

我們在上網(wǎng)的時候,都會用到瀏覽器,但是瀏覽器并非擁有我們想要的所有功能,我們可以根據(jù)自己的需要,實現(xiàn)自己的插件來滿足需求。比如網(wǎng)頁中經(jīng)常會有大量的廣告,如果你希望擁有一個純凈的網(wǎng)頁,可以實現(xiàn)一個插件來刪除網(wǎng)頁中的廣告部分,如果你覺得瀏覽器自帶的下載工具不太方便,可實現(xiàn)一個插件來管理下載的所有文件,文本以實現(xiàn)一個記錄所有打開的網(wǎng)頁地址為例,分享一下對瀏覽器插件開發(fā)的認(rèn)識。

要實現(xiàn)一個瀏覽器插件,需要從一個配置文件開始,這個配置文件就是manifest.json文件,任何插件的實現(xiàn)都離不開這個JSON格式的文件。

初識manifest.json文件

設(shè)置基本信息

           "manifest_version": 2, // 文件版本,基本不變
           "name": "Record Web Address Extension", // 這里輸入插件名稱
           "version": "1.0.1", // 自己實現(xiàn)的插件版本,在打包完插件的時候,根據(jù)這個字段來判斷插件是否需要更新
           "description": "The first extension that yangyanjun made.", // 這里輸入對此插件的詳細描述 以上幾個字段給插件添加一個入口。

設(shè)置入口信息

           "browser_action": { 
               "default_icon": "pinzhi_logo.png",
               "default_title": "記錄瀏覽地址", 
               "default_popup": "popup.html" 
            }

"browser_action" 字段配置好之后,插件加載后在瀏覽器的地址欄右側(cè)就會生成一個入口圖標(biāo),如下圖所示。

"default_icon"字段配置圖標(biāo)的地址,

"default_title"字段配置鼠標(biāo)移到圖標(biāo)上顯示的文字,

"default_popup"配置單擊圖標(biāo)所執(zhí)行的文件。

需要注意的是,這里的文件地址都是相對路徑,相對于manifest.json文件。

3.設(shè)置此插件所能訪問的瀏覽器權(quán)限

            "permissions": [ 
                "http://*/*",
                "https://*/*",
                "tabs",
                "storage"
            ]   

"permissions"字段是一個數(shù)組,列出本插件所使用到的瀏覽器權(quán)限,如果這里沒有授權(quán),則插件是無法使用的。此插件用到的瀏覽器的權(quán)限。

4.設(shè)置插件后臺頁面。

    "background":{
        "page":"background.html"
    }

"background"字段表明插件所運行的環(huán)境,在瀏覽器前臺看不到的頁面,需要打開擴展程序的開發(fā)者模式才能看到。如下圖所示:

5.設(shè)置對頁面內(nèi)容進行操作的腳本

    "content_scripts": [{  //對頁面內(nèi)容進行操作的腳本
         "matches": ["http://*/*","https://*/*"],  
         "js": ["js/jquery-1.9.1.min.js", "js/js.js"],
         "run_at": "document_start",  
         "all_frames": true
    }]

"matches"字段設(shè)置執(zhí)行該腳本的環(huán)境,比如本插件的該腳本在http或https協(xié)議下才執(zhí)行,在其他協(xié)議的網(wǎng)頁中是不執(zhí)行內(nèi)容腳本的。
"js"字段依次加載腳本文件地址。
"run_at"指定在document加載時執(zhí)行該腳本

插件中幾個環(huán)境的總結(jié)

popup.html: 點擊插件圖標(biāo)所顯示的頁面,只有點擊圖標(biāo)才會顯示,這可區(qū)別于background.html的運行周期。這個頁面中運行的js腳本叫做popup.js,它會在每次點擊插件入口圖標(biāo)時重新載入。 popup.html頁面如下圖所示:

background.html: 這個頁面是插件運行的后臺頁面,沒有顯示在窗口中,與當(dāng)前瀏覽頁面無關(guān)。這個頁面存在于插件運行的整個周期。插件啟動后就常駐后臺,只有一個,這個頁面運行的js腳本叫做background.js。

content.js:這個是注入在web頁面中的JavaScript腳本,可以是多個,如上所述,可以設(shè)置注入條件。

注意:chrome不允許擴展中的HTML頁面內(nèi)直接內(nèi)嵌js腳本,要求所有的腳本都作為外部src來引入。

三個主要部分消息傳遞總結(jié)

popup調(diào)用background中變量或方法:

   let bgMessage = chrome.extension.getBackgroundPage(); //可直接獲取background頁面
   console.log(bgMessage.tabUrl);  //直接調(diào)用background的變量或方法。   

background調(diào)用popup中變量或方法:

   let popMessage = chrome.extension.getViews({type:"popup"});//可直接獲取popup頁面
   console.log(popMessage[0].name); // 調(diào)用第一個popup的變量或方法。

注意: 因為個Extension可以同時擁有若干個頁面。這些頁面分為五種類型為除了background和popup頁面外,還有tab:像正常網(wǎng)頁一樣在瀏覽器的Tab中打開的頁面、infobar:在瀏覽器頂部信息欄顯示的信息頁面、notification:在瀏覽器底部顯示的通知頁面。它們分別代表在不同窗口打開的頁面。 所以這里一定要指定獲取頁面的type類型,如果沒有指定,則獲取Background Page之外的所有Extension Page的window對象。

內(nèi)容腳本發(fā)消息給background

   chrome.runtime.sendMessage({conyent: message || "我是content-script"},
   function(response) {
           console.log("來自background的回復(fù):" + response);
       }
   );
   

background監(jiān)聽內(nèi)容腳本所發(fā)送的消息,并作出回應(yīng)

   chrome.runtime.onMessage.addListener(function(request, sender, sendResponse)
   {
    ...
    sendResponse(JSON.stringify(request)); // 監(jiān)聽到消息之后,對收到的消息做一些處理并做出回應(yīng)
   });

本插件實現(xiàn)的兩個重要點

獲取當(dāng)前tab頁面的url

這部分邏輯要寫在background.js中,可以直接使用谷歌提供的插件接口來獲取當(dāng)前頁面的url
chrome.tabs.onUpdated.addListener(function(tabId, changeInfo, tab) {
    console.log(tab.url) //可以獲取當(dāng)前頁面的url地址
})

將獲取的url地址存儲起來

 可以使用谷歌的storage來存儲,由于在manifest.json中已經(jīng)授予了storage權(quán)限,所以這里可以直接使用   
 chrome.storage.local.set({"address": tabUrl}, function() {
    console.log("success")
  } )  

可以選擇同步的方式或者本地方式存儲,若選擇前者(sync), 存儲的數(shù)據(jù)會自動同步到你登錄的任何Chrome瀏覽器。若選擇storage.local,則只能夠?qū)?shù)據(jù)存儲在當(dāng)前登錄的設(shè)備本地。詳細用法可參見 https://developer.chrome.com/...

加載調(diào)試

設(shè)置 —>拓展程序—>加載已解壓的拓展程序—>選擇manifest.json所在的文件夾即可

注意:代碼修改之后,需要重新加載文件。

小結(jié)

本文只是簡單分享了如何開發(fā)一個簡單的谷歌瀏覽器插件,以及一些注意事項,并且提到了如何授權(quán)和使用谷歌插件api,重點介紹了插件開發(fā)必備的manifest.json入口文件和插件中幾個重要環(huán)境以及環(huán)境之間的通信。本文內(nèi)容并不是很全面,就當(dāng)是chrome插件開發(fā)的學(xué)習(xí)筆記,不足之處還望指出。本文內(nèi)容并未完結(jié),在以后學(xué)習(xí)的過程中,會不斷補充。

參考資料:
https://developer.chrome.com/...
https://developer.chrome.com/...
https://blog.csdn.net/luoshen...

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/99853.html

相關(guān)文章

  • 實現(xiàn)一個簡單chrome插件

    摘要:小結(jié)本文只是簡單分享了如何開發(fā)一個簡單的谷歌瀏覽器插件,以及一些注意事項,并且提到了如何授權(quán)和使用谷歌插件,重點介紹了插件開發(fā)必備的入口文件和插件中幾個重要環(huán)境以及環(huán)境之間的通信。 我們在上網(wǎng)的時候,都會用到瀏覽器,但是瀏覽器并非擁有我們想要的所有功能,我們可以根據(jù)自己的需要,實現(xiàn)自己的插件來滿足需求。比如網(wǎng)頁中經(jīng)常會有大量的廣告,如果你希望擁有一個純凈的網(wǎng)頁,可以實現(xiàn)一個插件來刪除網(wǎng)...

    lieeps 評論0 收藏0
  • 實現(xiàn)一個簡單chrome插件

    摘要:小結(jié)本文只是簡單分享了如何開發(fā)一個簡單的谷歌瀏覽器插件,以及一些注意事項,并且提到了如何授權(quán)和使用谷歌插件,重點介紹了插件開發(fā)必備的入口文件和插件中幾個重要環(huán)境以及環(huán)境之間的通信。 我們在上網(wǎng)的時候,都會用到瀏覽器,但是瀏覽器并非擁有我們想要的所有功能,我們可以根據(jù)自己的需要,實現(xiàn)自己的插件來滿足需求。比如網(wǎng)頁中經(jīng)常會有大量的廣告,如果你希望擁有一個純凈的網(wǎng)頁,可以實現(xiàn)一個插件來刪除網(wǎng)...

    fjcgreat 評論0 收藏0
  • Chrome插件開發(fā)入門:如何實現(xiàn)一鍵上班賴皮

    摘要:老板查崗時,一個快捷鍵,立即關(guān)閉所有賴皮頁面。上傳,發(fā)布插件。從零開始,開發(fā)簡單的一鍵賴皮插件的上班族都在使用瀏覽器賴皮,所以我們選擇采用插件來實現(xiàn)功能。 很多人介紹過Chrome插件,但必須要說,插件開發(fā)就是擺弄一個小玩具,第一要素是實用,其次是好玩。 單純羅列各種功能是非常無趣的。 所以把一篇舊文拿出來與大家分享。 人,活著就是為了賴皮。 作為一個合格的開發(fā)人員,把30%的時間用...

    acrazing 評論0 收藏0
  • 使用LeanCloud服務(wù)做一站式Chrome插件開發(fā)——Favorite Image

    摘要:云存儲問題,帳號系統(tǒng),多端同步最開始只想做瀏覽器本地的存儲,使用提供的存在本地就。具體解決方案云存儲及帳號系統(tǒng)使用提供的存儲服務(wù)解決。 0. 目錄 要開發(fā)的是什么項目 1.1 想法開端 1.2 應(yīng)該有什么功能? 開發(fā)需要解決的核心問題 具體解決方案 3.1 帳號系統(tǒng) 3.2 存儲服務(wù) 3.3 使用`LeanEngine`做反防盜鏈中轉(zhuǎn)接口 3.4 Chrome 插件實現(xiàn) 對去...

    JohnLui 評論0 收藏0
  • 五分鐘實現(xiàn)一個chrome插件(含源碼)

    摘要:找了一下網(wǎng)上應(yīng)用商店,其實已經(jīng)有很多款類似插件,但往往太過陳舊或者性能較差,不能夠滿足個人需求,估自己搗鼓了一個插件。 代碼已經(jīng)在github更新了 https://github.com/abc-club/c... 請移步github。另外喜歡的話請star。求star求star求star 本文已同步到 https://github.com/abc-club/f... 背景 很多網(wǎng)站都...

    mengbo 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<