chrome擴展開發(fā)整理以及那個學習

顧名思義悍缠,chrome擴展,就是chrome瀏覽器的擴展耐量。

chrome擴展飞蚓,是使用chrome本身api開發(fā)的工具。
chrome插件廊蜒,我沒記錯的話是基于webkit內核NPAPI (新版本是PPAPI)開發(fā)出來的工具玷坠。
本質上二者好像就不一樣。

先來BB一下大體構成劲藐。后面詳細。

  • manifest.json 個人理解嘛樟凄,這玩意兒就和package.json差不多聘芜,就是配置文件。后面BB這個的api缝龄。

  • background 這個東西汰现,就是和chrome打交道的了。叫后臺頁面叔壤。就是告訴chrome你是要干啥瞎饲,你是要持續(xù)運行的后臺頁面呢,還是就是一個單純的事件頁面呢炼绘。

  • popup 如果你需要操作這個拓展程序嗅战,那就需要這個東西了。這個是一個純web頁面俺亮。

  • Content scripts -- 內容腳本驮捍,就是連接background和popup的媒介。

     popup告訴內容腳本要干啥脚曾。內容腳本讓background去干啥东且。
    
看清楚

manifest的api來了(沒錯,就是mani本讥,不是main)

{
    //必須得有的
    "manifest_version" : 2, //這里  是且只能是2   api里只有2珊泳,姑且這么認為
    "name" : "nicaicai", //就是你這個chrome拓展叫啥
    "version" : "1.0.0",  //你這個拓展的版本

    //最好是有的
    "default_locale" : "zh_CN", //這個拓展是給哪國人看的
    "description" : "介紹一下這個拓展是干啥的",
    
    //愛有沒有鲁冯,有就有一個
    "browser_action":{
        //擴展再瀏覽器右上角那個小圖標
        "default_icon": "img/icon.png",
        // 鼠標在圖標懸停時的標題,想要就要色查,不想要就拉倒
        "default_title": "什么玩意兒的擴展",
        //這個擴展的首頁薯演,根據目錄結構來。
        "default_popup": "popup.html"    
    },
    //下面這個和上面最好活一個综慎,不要都活下來
    "page_action":{
        "default_icon": "img/icon.png",
        "default_title": "愛啥啥",
        "default_popup": "popup.html"
    },

    //下面這些就隨意發(fā)揮了
    "action" : "我不知道是干啥的",
    "author" : "誰干的(肯定句)",
    "automation" : "上一句的上一句",

    //敲黑板涣仿。這個是長駐在后臺執(zhí)行的東西
    "background"  : {
      //  用js的形式,會自動生成一個后臺頁面
        "scripts": [
            "js/background.js"http://目錄就是上面的那個background.js在你本地項目里的目錄地址
        ]
  
        //或者示惊,二者活一個
        "page": "background.html"
    },
    // 需要直接注入頁面的JS
    "content_scripts": 
    [
        {
            //"matches": ["http://*/*", "https://*/*"],
            // "<all_urls>" 表示匹配所有地址
             //下面這種寫法也可以好港,matches后面是數(shù)組或者string就可以
              // "http://*/",
              //  "https://*/",
              // "http://*/*",
              // "https://*/*"
            
            "matches": ["<all_urls>"],
            // 如果有好幾個js的話,就按順序注入
            "js": ["js/jquery-1.8.3.js", "js/content-script.js"],
           // js如果沒有啥依賴的米罚,可以隨便順序
          //  css最好按照順序來钧汹,免得覆蓋
            "css": ["css/index.css"],
            // 代碼注入的時間,可設置的值: "document_start", "document_end", or "document_idle"录择,最后一個表示頁面空閑時拔莱,默認document_idle
            "run_at": "document_start"
        }
    ],
     //再敲一次黑板,如果你要用chromeAPI中的一些東西隘竭,要在這里列出來你要用的‘權限’塘秦。可以使用的有很多动看,不一一舉例了尊剔。
    "permissions" : [
        "contextMenus", // 右鍵菜單
        "tabs", // 標簽
        "http://*/*",
        "https://*/*"
    ]
}

以上這些,基本上夠用0.0 如果有特殊需求菱皆,可以自己找api里你需要的须误。英語不好,有些不知道怎么解釋仇轻。
都是授予對chrome.xxxapi的擴展訪問權限

咳咳京痢。大體api說一下,下面再BB點我覺得有用的篷店。祭椰。。船庇。
開發(fā)過程中吭产,在background.js頁面里,可以使用一些chrome.xx.xx這種語法來綁定相關事件

// 接收消息
chrome.runtime.onMessage.addListener(function(request, sender, sendResponse) {
    if (request.result) {
        sendResponse({
            farewell: "ok"
        });
    }

    localStorage.setItem("key", request.msg);
});

"scripts": ["js/background.js"]這里就是接受信息的js鸭轮。

在content 頁面里

// 發(fā)送消息
chrome.runtime.sendMessage(
    {
        msg: '從 Content Script 向 事件頁面 傳遞消息',
        result: 1
    },
    function(response) {
        if (response && response.msg) {
            console.log(response.msg);
        }
    }
);

這個js文件相當于是入口js文件臣淤,要在你的"default_popup": "popup.html"這里對應的html中引入。

以上就是大體操作窃爷,總之邑蒋,用到chromeAPI里的姓蜂,需要傳遞的就要在內容頁面里發(fā)送,在持續(xù)在后臺執(zhí)行的js中接受医吊。這樣才能實時滿足你钱慢。

那么,開發(fā)完了卿堂,如果想讓更多人使用要怎么做呢束莫?


登錄到 Chrome 開發(fā)者信息中心,以便你可以發(fā)布到Chrome應用商店草描。

首先览绿,你需要有一個 Google 帳號,去注冊一個穗慕。
然后打包成*.zip饿敲,上傳上去。
但是逛绵,這個上傳是需要收費的怀各。。术浪。
chrome會索要 5刀 的開發(fā)者注冊費用瓢对,給錢之后,你可以上傳20個擴展了胰苏。沥曹。
PS:貌似得用visa卡才能支付

如果只是小范圍內使用,可以直接打包發(fā)送出去碟联,使用者添加到chrome擴展就好了。

本文僅供學習筆記使用僵腺。鲤孵。。無抄襲之意辰如、普监、、歡迎糾錯琉兜。凯正。。

補一句豌蟋,開發(fā)過程中修改backgroundcontent Script的時候廊散,要移除擴展再次添加,才有效梧疲,類似于popup頁面的css允睹、js运准,刷新就有效。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末缭受,一起剝皮案震驚了整個濱河市胁澳,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌米者,老刑警劉巖韭畸,帶你破解...
    沈念sama閱讀 211,290評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異蔓搞,居然都是意外死亡胰丁,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評論 2 385
  • 文/潘曉璐 我一進店門败明,熙熙樓的掌柜王于貴愁眉苦臉地迎上來隘马,“玉大人,你說我怎么就攤上這事妻顶∷嵩保” “怎么了?”我有些...
    開封第一講書人閱讀 156,872評論 0 347
  • 文/不壞的土叔 我叫張陵讳嘱,是天一觀的道長幔嗦。 經常有香客問我,道長沥潭,這世上最難降的妖魔是什么邀泉? 我笑而不...
    開封第一講書人閱讀 56,415評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮钝鸽,結果婚禮上汇恤,老公的妹妹穿的比我還像新娘。我一直安慰自己拔恰,他們只是感情好因谎,可當我...
    茶點故事閱讀 65,453評論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著颜懊,像睡著了一般财岔。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上河爹,一...
    開封第一講書人閱讀 49,784評論 1 290
  • 那天匠璧,我揣著相機與錄音,去河邊找鬼咸这。 笑死夷恍,一個胖子當著我的面吹牛,可吹牛的內容都是我干的媳维。 我是一名探鬼主播裁厅,決...
    沈念sama閱讀 38,927評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼冰沙,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了执虹?” 一聲冷哼從身側響起拓挥,我...
    開封第一講書人閱讀 37,691評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎袋励,沒想到半個月后侥啤,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經...
    沈念sama閱讀 44,137評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡茬故,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,472評論 2 326
  • 正文 我和宋清朗相戀三年盖灸,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片磺芭。...
    茶點故事閱讀 38,622評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡赁炎,死狀恐怖,靈堂內的尸體忽然破棺而出钾腺,到底是詐尸還是另有隱情徙垫,我是刑警寧澤,帶...
    沈念sama閱讀 34,289評論 4 329
  • 正文 年R本政府宣布放棒,位于F島的核電站姻报,受9級特大地震影響,放射性物質發(fā)生泄漏间螟。R本人自食惡果不足惜吴旋,卻給世界環(huán)境...
    茶點故事閱讀 39,887評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望厢破。 院中可真熱鬧荣瑟,春花似錦、人聲如沸摩泪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽加勤。三九已至,卻和暖如春同波,著一層夾襖步出監(jiān)牢的瞬間鳄梅,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工未檩, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留戴尸,地道東北人。 一個月前我還...
    沈念sama閱讀 46,316評論 2 360
  • 正文 我出身青樓冤狡,卻偏偏與公主長得像孙蒙,于是被迫代替她去往敵國和親项棠。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,490評論 2 348

推薦閱讀更多精彩內容