国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

實(shí)現(xiàn)一個(gè)簡單的chrome插件

rubyshen / 1207人閱讀

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

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

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

初識(shí)manifest.json文件

設(shè)置基本信息

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

設(shè)置入口信息

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

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

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

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

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

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

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

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

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

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

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

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

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

    "content_scripts": [{  //對(duì)頁面內(nèi)容進(jìn)行操作的腳本
         "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加載時(shí)執(zhí)行該腳本

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

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

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

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

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

三個(gè)主要部分消息傳遞總結(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)用第一個(gè)popup的變量或方法。

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

內(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)聽到消息之后,對(duì)收到的消息做一些處理并做出回應(yīng)
   });

本插件實(shí)現(xiàn)的兩個(gè)重要點(diǎ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地址存儲(chǔ)起來

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

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

加載調(diào)試

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

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

小結(jié)

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

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

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

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/99853.html

相關(guān)文章

  • 實(shí)現(xiàn)一個(gè)簡單chrome插件

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

    lieeps 評(píng)論0 收藏0
  • 實(shí)現(xiàn)一個(gè)簡單chrome插件

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

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

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

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

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

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

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

    mengbo 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<