Chrome擴展開發(fā)入門體驗

****前言****
Chrome瀏覽器擴展開發(fā)算是相當(dāng)簡單的,基本只要掌握HTML+CSS+Javascript刹帕,即可快速開發(fā)一個屬于你的Chrome插件!


****Chrome擴展基本目錄結(jié)構(gòu)****

manifest.json  這是一個配置文件,里面記錄了擴展的使用范圍啦辐、作者卓嫂、版本慷暂、其余需要加載的文件等內(nèi)容;
icon.png       這個一看便知,就是擴展的圖標(biāo)~~~
popup.html     點擊擴展圖標(biāo)晨雳,彈出的面板頁面(如果在manifest.json中配置了default_popup為該文件的話)
popup.js       popup面板加載的js腳本文件
popup.css      popup面板加載的css樣式文件  
  • 具體分析manifest.json插件的配置文件
{  
    "name": "Alic",  //插件的名稱
    "version": "0.1.0", //擴展的版本
    "manifest_version":2, //這個是必須的行瑞,并且值為2
    "description": "Chrome擴展demo",  //擴展的基本描述
    "browser_action": {  
        "default_icon": "icon.png" , //插件圖標(biāo)icon位置
        "default_title": "默認(rèn)標(biāo)題", //鼠標(biāo)hover是的標(biāo)題
        "default_popup": "popup.html" //單擊圖標(biāo)popup出來的面板
    },
    "permissions":[
        "http://www.samego.com"
    ]
} 

其它屬性的詳細(xì)說明
permissions
permissions 屬性是一個數(shù)組,它定義了擴展需要向 Chrome 申請的權(quán)限餐禁,比如通過 XMLHttpRequest 跨域請求數(shù)據(jù)血久、訪問瀏覽器選項卡(tabs)、獲取當(dāng)前活動選項卡(activeTab)帮非、瀏覽器通知(notifications)氧吐、存儲(storage)等,可以根據(jù)需要添加末盔。

{
    "permissions": [
        "http://api.example.com/api/"
        "tabs",
        "activeTab",
        "notifications",
        "storage"
    ]
}

background
background 可以使擴展常駐后臺筑舅,比較常用的是指定子屬性 scripts,表示在擴展啟動時自動創(chuàng)建一個包含所有指定腳本的頁面陨舱。

{
    "background": {
        "scripts": ["./public/js/background.js"]
    }
}

chrome_url_overrides
chrome_url_overrides 屬性可以自定義的頁面替換 Chrome 相應(yīng)默認(rèn)的頁面翠拣,比如新標(biāo)簽頁(newtab)、書簽頁面(bookmarks)和歷史記錄(history)游盲。

{
    "chrome_url_overrides": {
        "newtab": "tab.html"
    }
}

****Chrome擴展調(diào)試****
menu->設(shè)置->擴展程序
注意:將開發(fā)者模式選中~~~
The first = 點擊加載已解壓的擴展程序误墓,并選擇擴展程序的目錄
完成后會在項目的根目錄生成xx.crx以及xx.pem兩個文件
The second = 查看瀏覽器的工具欄

我的插件dir-tree

Alic_dir

ALic_Chrome

Alic_Chrome

簡單的擴展插件就完成了 ~~~


****background交互****
簡單來說呢,上面完成的其實就是一個擴展程序的微框架益缎。
background顧名思義呢就是擴展程序的后臺腳本谜慌,該腳本在程序運行之后一直處于后臺運行狀態(tài)。記錄常用的API链峭。

在background里綁定browserAction的點擊事件定義事件響應(yīng)處理

chrome.browserAction.onClicked.addListener(function(){  
     //to-do
});

調(diào)用chrome.tabs.create()來創(chuàng)建新的tab畦娄,url既可以是path也可以是網(wǎng)址

chrome.tabs.create({url: "./home/index.html"});

content script調(diào)用background方法
在background腳本定義方法

// 創(chuàng)建新標(biāo)簽頁的自定義方法
function testDynamic(){
    chrome.tabs.create({url: "./home/index.html"});
}

在content script使用content script里定義的方法

var bg = chrome.extension.getBackgroundPage();   
bg.testDynamic();

content script與background交互
content script監(jiān)聽消息:

chrome.extension.onRequest.addListener(function(request, sender, sendResponse) {});  

background發(fā)送消息:

chrome.tabs.sendRequest(tab.id, data, function(data) {});  

相反~~~

background監(jiān)聽消息:

chrome.extension.onRequest.addListener(function(request, sender, sendResponse) {});  

content script側(cè)發(fā)送消息:

chrome.extension.sendRequest(data, function(data) {}); 

開發(fā)一個簡單Chrome擴展程序基本是沒有什么大問題的!我的體會呢弊仪,要是主要用于離線的呢熙卡,還是開發(fā)應(yīng)用好點,擴展程序也不是不可以励饵,否則數(shù)據(jù)存儲方面就使用js處理即可驳癌!


****價值源于技術(shù),貢獻源于分享****

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末役听,一起剝皮案震驚了整個濱河市颓鲜,隨后出現(xiàn)的幾起案子表窘,更是在濱河造成了極大的恐慌,老刑警劉巖甜滨,帶你破解...
    沈念sama閱讀 206,839評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件乐严,死亡現(xiàn)場離奇詭異,居然都是意外死亡衣摩,警方通過查閱死者的電腦和手機昂验,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來艾扮,“玉大人既琴,你說我怎么就攤上這事∨葑欤” “怎么了甫恩?”我有些...
    開封第一講書人閱讀 153,116評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長酌予。 經(jīng)常有香客問我磺箕,道長,這世上最難降的妖魔是什么霎终? 我笑而不...
    開封第一講書人閱讀 55,371評論 1 279
  • 正文 為了忘掉前任滞磺,我火速辦了婚禮,結(jié)果婚禮上莱褒,老公的妹妹穿的比我還像新娘击困。我一直安慰自己,他們只是感情好广凸,可當(dāng)我...
    茶點故事閱讀 64,384評論 5 374
  • 文/花漫 我一把揭開白布阅茶。 她就那樣靜靜地躺著,像睡著了一般谅海。 火紅的嫁衣襯著肌膚如雪脸哀。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,111評論 1 285
  • 那天扭吁,我揣著相機與錄音撞蜂,去河邊找鬼。 笑死侥袜,一個胖子當(dāng)著我的面吹牛蝌诡,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播枫吧,決...
    沈念sama閱讀 38,416評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼浦旱,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了九杂?” 一聲冷哼從身側(cè)響起颁湖,我...
    開封第一講書人閱讀 37,053評論 0 259
  • 序言:老撾萬榮一對情侶失蹤宣蠕,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后甥捺,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體抢蚀,經(jīng)...
    沈念sama閱讀 43,558評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,007評論 2 325
  • 正文 我和宋清朗相戀三年涎永,在試婚紗的時候發(fā)現(xiàn)自己被綠了思币。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,117評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡羡微,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出惶我,到底是詐尸還是另有隱情妈倔,我是刑警寧澤,帶...
    沈念sama閱讀 33,756評論 4 324
  • 正文 年R本政府宣布绸贡,位于F島的核電站盯蝴,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏听怕。R本人自食惡果不足惜捧挺,卻給世界環(huán)境...
    茶點故事閱讀 39,324評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望尿瞭。 院中可真熱鬧闽烙,春花似錦、人聲如沸声搁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽疏旨。三九已至很魂,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間檐涝,已是汗流浹背遏匆。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留谁榜,地道東北人幅聘。 一個月前我還...
    沈念sama閱讀 45,578評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像惰爬,于是被迫代替她去往敵國和親喊暖。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,877評論 2 345

推薦閱讀更多精彩內(nèi)容