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

資訊專欄INFORMATION COLUMN

一個簡單的chrome拓展程序開發(fā)

vslam / 493人閱讀

摘要:相當于發(fā)一個命令。這個函數(shù)能獲取到當前標簽的信息對象并傳遞給回調(diào)函數(shù)。向標簽頁中的發(fā)送消息。接收到消息,執(zhí)行操作。會彈出一個控制臺。這樣我們就完成了一個簡單的插件。

最近突然覺得有些常用的功能可以寫成瀏覽器插件,就不用把代碼放到console控制臺運行了。只要點擊插件圖標就可以自動運行。會方便很多。就去查了下chrome插件開發(fā)教程。本質(zhì)上講,chrome插件就是以一些特殊的方式運行一些特定的html,css,JavaScript代碼,前端同學們學起來還是很容易的。

比較好的中文的參考資料:
1.360翻譯的文檔:http://open.chrome.360.cn/ext...
2.Chrome擴展及應用開發(fā):http://www.ituring.com.cn/min...

我們做一個簡單的插件:實現(xiàn)點擊插件圖標可以給頁面上所有的a標簽加上一個target="_blank",讓點所有鏈接都在新頁面打開。
我們開發(fā)的應用這樣使用:

1.建立一個文件夾。a chrome plugin。
2.新建配置文件 manifest.json。前端同學們對于這樣的配置文件一定不陌生。
里同包含了版本號,插件名稱,默認頁面,content_scripts,permissions等基本信息。
這個文件能將我們插件中的的js,css,JavaScript文件組織起來。
具體每個參數(shù)的含義見文檔:http://open.chrome.360.cn/ext...
代碼:

{
    "manifest_version": 2,
    "name": "A",
    "version": "1.0",
    "description": "新標簽打開鏈接",
    "browser_action": {
        "default_popup": "popup.html"
    },
    "content_scripts":[
        {
            "matches": ["http://*/*","https://*/*"],
            "js": ["back.js"],
            "run_at":"document_end"
        }
    ],
    "permissions": [
        "tabs"
    ]
}

3.建立文件。popup.html。
對應配置文件中的 "default_popup": "popup.html"。

點圖標的時候我們會加載運行這個html,運行這個html引入的js。
這是一個普通的html頁面。里面可以寫css。也可以加載JavaScript文件。也可以給里面的節(jié)點添加事件什么的。
不過這個文件以及加載的js無法訪問當前我們打開的標簽頁中的dom節(jié)點。
代碼:



    


    這是popup.html里面。


這里只用來加載一個js。

4.popup.js。 popup.html引入的js。這里我們用戶它的做的事是向content_scripts中發(fā)送一個消息。相當于發(fā)一個命令。告訴content script,去辦事吧。content_scripts的內(nèi)容在后面,看完再回過來看一次這里。

    chrome.tabs.getSelected(null, function(tab) {
        chrome.tabs.sendRequest(tab.id, {greeting: "hello"}, function(response) {
            // console.log(response.farewell);
        });
    });

chrome.tabs.getSelected()這個函數(shù)能獲取到當前標簽的信息對象并傳遞給回調(diào)函數(shù)。 
獲取到tabId就是tab.id。可以自己console.log(tab)出來看一下。文章后面有對應調(diào)試控制臺的打開方式。tab相關(guān)的接口可以查看:http://open.chrome.360.cn/ext... 很多接口都要用到這個參數(shù):tabId ( integer ),其實就是用這個接口拿到tabId。

chrome.tabs.sendRequest()這個函數(shù)是向某個標簽的content_script中發(fā)送一個消息。也需要tabId這個參數(shù)。chrome插件之間的通信接口可查看 :http://open.chrome.360.cn/ext...

5.back.js。也是我們這個插件中的content script。
這個文件是我們插入到當前標簽頁中運行的代碼。它可以訪問標簽頁面中的dom節(jié)點。
我們這里用它來是監(jiān)聽消息,消息來了就運行設(shè)置標簽的函數(shù)。操作標簽頁中的dom節(jié)點。

對應配置文件中content_scripts下的back.js。
這個參數(shù)中的內(nèi)容會被加載到當前打開的網(wǎng)頁中,可以訪問當前標簽頁的節(jié)點。
所以,我們對頁面的操作往往會寫在這個腳本里。有需要的話甚至可以加載個jQuery到里面。
但是這里的JavaScript與網(wǎng)頁上原本的JavaScript不是一個環(huán)境下運行。具體區(qū)別可以自己去看開發(fā)文檔。http://open.chrome.360.cn/ext...
代碼:

function setA(){
    var aDoms = document.getElementsByTagName("a");
    var len = aDoms.length;
    for (var i = 0; i < len; i++) {
        aDoms[i].setAttribute("target","_blank")
    }
}
chrome.extension.onRequest.addListener(
    function(request, sender, sendResponse) {
        if (request.greeting == "hello"){
            setA();
            // sendResponse({farewell: "goodbye"});
        }else{
              // sendResponse({});
          }
      }
      );

可能比較要注意的一點是popup.html與content_script之間的通信。
popup.html向標簽頁中的content_script發(fā)送消息。
content_script接收到消息,執(zhí)行操作。

6.調(diào)試方式:
popup.html加載的js調(diào)試。
右鍵點擊插件圖標,選擇審查彈出內(nèi)容。(或者在彈出框里右鍵點擊檢查。)會彈出一個控制臺。
點source可以看到我們的html和js資源。

content_script的調(diào)試:
打開頁面控制臺,點sources,然后點Contents scripts,可以看到瀏覽器插件會作用到頁面的代碼。

注意每次修改了代碼要重新加載插件。

這樣我們就完成了一個簡單的chrome插件。

github:https://github.com/liusaint/J...
本文同步發(fā)表在我的csdn博客上:http://blog.csdn.net/liusaint...

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

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

相關(guān)文章

  • chrome擴展開發(fā)

    摘要:這是本人寫的第一個擴展,這個擴展的普遍適用性不強,但是確實很方便,具體的開發(fā)流程寫在這里,感興趣的看官可以試著自己動手寫一寫這個擴展的作用是,它的適用場景是更換百度搜索頁的關(guān)鍵詞,并且跳轉(zhuǎn),如果你理解了這個意思,那你一定會想這能有什么用,是 這是本人寫的第一個chrome擴展,這個擴展的普遍適用性不強,但是確實很方便,具體的開發(fā)流程寫在這里,感興趣的看官可以試著自己動手寫一寫 這個擴展...

    yedf 評論0 收藏0
  • 《JavaScript高級程序設(shè)計》(第3版)讀書筆記 第11章 DOM拓展

    摘要:對的兩個主要拓展是選擇和。以下插入標記的拓展已經(jīng)納入了規(guī)范。在寫模式下,會根據(jù)指定的字符串創(chuàng)建新的子樹,然后用這個子樹完全替換調(diào)用元素。在刪除帶有時間處理程序或引用了其他對象子樹時,就有可能導致內(nèi)存占用問題。 盡管DOM作為API已經(jīng)非常完善了,但為了實現(xiàn)更多功能,仍然會有一些標準或?qū)S械耐卣埂?008年之前,瀏覽器中幾乎所有的拓展都是專有的,此后W3C著手將一些已經(jīng)成為事實標準的專...

    luck 評論0 收藏0
  • Chrome 擴展開發(fā)——編寫一個自己瀏覽器插件

    摘要:配置文件每一個擴展都有一個格式的文件,叫。此消息發(fā)送后會觸發(fā)擴展內(nèi)每個頁面的事件。和持續(xù)長時間的保持會話需要在和擴展建立一個長時間存在的通道。內(nèi)容腳本發(fā)送消息到擴展程序建立通道,并給通道命名利用通道發(fā)送一條消息。 這次的練習是做一個Chrome的擴展,分享一下入門開發(fā)過程。因為在消息傳遞那塊糾結(jié)了特別久,所以我會重點總結(jié)消息傳遞那塊。 這次做這個插件的功能很簡單,就是點擊按鈕后可以對當...

    SunZhaopeng 評論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)...

    rubyshen 評論0 收藏0

發(fā)表評論

0條評論

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