webExtension 瀏覽器插件(chrome)

介紹

擴(kuò)展由不同的但相互聯(lián)系的組件組成智哀。組件可以包括后臺腳本留美,內(nèi)容腳本拇颅,選項(xiàng)頁奏司,UI元素和各種邏輯文件。擴(kuò)展組件是使用Web開發(fā)技術(shù)創(chuàng)建的:HTML蔬蕊,CSS和JavaScript结澄。擴(kuò)展的組件將取決于其功能,并且可能不需要所有選項(xiàng)岸夯。

manifest.json

{
    // 清單文件的版本麻献,這個(gè)必須寫,而且必須是2
    "manifest_version": 2,
    // 插件的名稱
    "name": "demo",
    // 插件的版本
    "version": "1.0.0",
    // 插件描述
    "description": "簡單的Chrome擴(kuò)展demo",
    // 圖標(biāo)猜扮,一般偷懶全部用一個(gè)尺寸的也沒問題
    "icons":
    {
        "16": "img/icon.png",
        "48": "img/icon.png",
        "128": "img/icon.png"
    },
    // 會一直常駐的后臺JS或后臺頁面
    "background":
    {
        // 2種指定方式勉吻,如果指定JS,那么會自動生成一個(gè)背景頁
        "page": "background.html"
        //"scripts": ["js/background.js"]
    },
    // 瀏覽器右上角圖標(biāo)設(shè)置旅赢,browser_action齿桃、page_action、app必須三選一
    "browser_action": 
    {
        "default_icon": "img/icon.png",
        // 圖標(biāo)懸停時(shí)的標(biāo)題煮盼,可選
        "default_title": "這是一個(gè)示例Chrome插件",
        "default_popup": "popup.html"
    },
    // 當(dāng)某些特定頁面打開才顯示的圖標(biāo)
    /*"page_action":
    {
        "default_icon": "img/icon.png",
        "default_title": "我是pageAction",
        "default_popup": "popup.html"
    },*/
    // 需要直接注入頁面的JS
    "content_scripts": 
    [
        {
            //"matches": ["http://*/*", "https://*/*"],
            // "<all_urls>" 表示匹配所有地址
            "matches": ["<all_urls>"],
            // 多個(gè)JS按順序注入
            "js": ["js/jquery-1.8.3.js", "js/content-script.js"],
            // JS的注入可以隨便一點(diǎn)短纵,但是CSS的注意就要千萬小心了,因?yàn)橐徊恍⌒木涂赡苡绊懭謽邮?            "css": ["css/custom.css"],
            // 代碼注入的時(shí)間僵控,可選值: "document_start", "document_end", or "document_idle"香到,最后一個(gè)表示頁面空閑時(shí),默認(rèn)document_idle
            "run_at": "document_start"
        },
        // 這里僅僅是為了演示content-script可以配置多個(gè)規(guī)則
        {
            "matches": ["*://*/*.png", "*://*/*.jpg", "*://*/*.gif", "*://*/*.bmp"],
            "js": ["js/show-image-content-size.js"]
        }
    ],
    // 權(quán)限申請
    "permissions":
    [
        "contextMenus", // 右鍵菜單
        "tabs", // 標(biāo)簽
        "notifications", // 通知
        "webRequest", // web請求
        "webRequestBlocking",
        "storage", // 插件本地存儲
        "http://*/*", // 可以通過executeScript或者insertCSS訪問的網(wǎng)站
        "https://*/*" // 可以通過executeScript或者insertCSS訪問的網(wǎng)站
    ],
    // 普通頁面能夠直接訪問的插件資源列表,如果不設(shè)置是無法直接訪問的
    "web_accessible_resources": ["js/inject.js"],
    // 插件主頁悠就,這個(gè)很重要千绪,不要浪費(fèi)了這個(gè)免費(fèi)廣告位
    "homepage_url": "https://www.baidu.com",
    // 覆蓋瀏覽器默認(rèn)頁面
    "chrome_url_overrides":
    {
        // 覆蓋瀏覽器默認(rèn)的新標(biāo)簽頁
        "newtab": "newtab.html"
    },
    // Chrome40以前的插件配置頁寫法
    "options_page": "options.html",
    // Chrome40以后的插件配置頁寫法,如果2個(gè)都寫梗脾,新版Chrome只認(rèn)后面這一個(gè)
    "options_ui":
    {
        "page": "options.html",
        // 添加一些默認(rèn)的樣式荸型,推薦使用
        "chrome_style": true
    },
    // 向地址欄注冊一個(gè)關(guān)鍵字以提供搜索建議,只能設(shè)置一個(gè)關(guān)鍵字
    "omnibox": { "keyword" : "go" },
    // 默認(rèn)語言
    "default_locale": "zh_CN",
    // devtools頁面入口炸茧,注意只能指向一個(gè)HTML文件瑞妇,不能是JS文件
    "devtools_page": "devtools.html"
}

實(shí)戰(zhàn)

訪問百度網(wǎng)頁時(shí)增加一個(gè)紅色框

  • 創(chuàng)建文件夾

    mkdir borderify
    
  • 創(chuàng)建 manifest.json文件進(jìn)行配置

    {
      "name": "添加邊框",
      "manifest_version": 2,
      "version": "1.0",
      "description": "添加邊框",
    
      "browser_action": {
        "default_icon": "img/icon.png",
        "default_title": "添加邊框"
      },
    
      "icons": {
        "16": "img/icon.png",
          "48": "img/icon.png",
          "128": "img/icon.png"
      },
      
      "content_scripts": [
        {
          "matches": ["*://*.baidu.com/*"],
          "js": ["borderify.js"]
        }
      ]
    }
    

    matches: 匹配規(guī)則 只匹配百度網(wǎng)址

    js:需要直接注入頁面的JS 文件

    icons:圖標(biāo)

  • 創(chuàng)建icon圖片img/icon.png

  • 創(chuàng)建borderify.js文件

    document.body.style.border = "5px solid red"
    
  • 整體目錄結(jié)構(gòu)

    image-20201229170601117.png
  • 添加插件

    image-20201229170909111.png
    image-20201229171034037.png
  • 訪問百度,查看效果

    image-20201229171216812.png

參考資料

【干貨】Chrome插件(擴(kuò)展)開發(fā)全攻略
官方文檔
API Reference
ReferenceError: browser is not defined
webextension-polyfill
Chrome擴(kuò)展及應(yīng)用開發(fā)
Firefox Extension

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末宇立,一起剝皮案震驚了整個(gè)濱河市踪宠,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌妈嘹,老刑警劉巖柳琢,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異润脸,居然都是意外死亡柬脸,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進(jìn)店門毙驯,熙熙樓的掌柜王于貴愁眉苦臉地迎上來倒堕,“玉大人,你說我怎么就攤上這事爆价】寻停” “怎么了?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵铭段,是天一觀的道長骤宣。 經(jīng)常有香客問我,道長序愚,這世上最難降的妖魔是什么憔披? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮爸吮,結(jié)果婚禮上芬膝,老公的妹妹穿的比我還像新娘。我一直安慰自己形娇,他們只是感情好锰霜,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著桐早,像睡著了一般锈遥。 火紅的嫁衣襯著肌膚如雪纫事。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天所灸,我揣著相機(jī)與錄音,去河邊找鬼炫七。 笑死爬立,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的万哪。 我是一名探鬼主播侠驯,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼奕巍!你這毒婦竟也來了吟策?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤的止,失蹤者是張志新(化名)和其女友劉穎檩坚,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體诅福,經(jīng)...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡匾委,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了氓润。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片赂乐。...
    茶點(diǎn)故事閱讀 38,137評論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖咖气,靈堂內(nèi)的尸體忽然破棺而出挨措,到底是詐尸還是另有隱情,我是刑警寧澤崩溪,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布浅役,位于F島的核電站,受9級特大地震影響悯舟,放射性物質(zhì)發(fā)生泄漏担租。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一抵怎、第九天 我趴在偏房一處隱蔽的房頂上張望奋救。 院中可真熱鬧,春花似錦反惕、人聲如沸尝艘。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽背亥。三九已至秒际,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間狡汉,已是汗流浹背娄徊。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留盾戴,地道東北人寄锐。 一個(gè)月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像尖啡,于是被迫代替她去往敵國和親橄仆。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,901評論 2 345