每次百度搜索,搜索結果的右邊老是出現些亂七八糟的搜索熱點(推的都是些什麼玩意,高校替課和我有毛關係,幾個悲傷的熱點我用星號頂掉了)。css
強迫症想把它隱藏掉,我用的是chrome瀏覽器,受adblock(超強屏蔽廣告插件)的啓發,想到作瀏覽器插件的方式。
本文簡單記錄一下插件開發過程,chrome插件開發真的很是簡單,只須要一點點前端的知識就能夠了,如下是本次插件開發、打包、安裝所有過程。
1、插件介紹
chrome插件,即chrome擴展程序,地址欄輸入chrome://extensions便可查看已安裝的插件(好比下圖中的第二個就是本次開發的插件):html
2、插件開發前端
{
"name": "BriskPage", // 插件名稱
"version": "0.0.8", // 插件版本號
"manifest_version": 2, // chrome18之後要求必須設置,否則打包會報錯
"description": "control the web page with CSS", // 對插件的簡單描述,本插件是經過CSS來簡單控制頁面那些元素隱藏
"browser_action": { // 配置插件的一些資源地址
"default_icon": "favicon.jpeg", // 圖標,須要提供圖標文件
"default_title": "清新網頁", // 標題
"default_popup": "popup.html" // 彈窗文件,就是點擊插件圖標,須要提供popup.html文件
},
"content_scripts": [ // 該項可無,不過若是咱們想操做頁面dom的話,是須要配置的
{
"matches": ["*://www.baidu.com/*"], // 對於百度站點網頁,注入brisk.js
"js": ["brisk.js"]
}
]
}
代碼很是簡單,就是動態建立一個style標籤,把隱藏Dom相應的CSS寫入後,插入原網頁,這樣就能達到隱藏相應dom的目的啦,這裏有個細節點的東西就是觀察原網頁變化,使用了MutationObserver實例對象,當頁面中Dom發生變化時,檢查頁面內是否有咱們插入的style標籤,有就不做任何處理,沒有則插入。代碼以下:git
// brisk.js function hideDom () { if (document.querySelector('style[brisk]')) return let style = document.createElement('style') style.setAttribute('type', 'text/css') style.setAttribute('brisk', true) style.innerHTML = ".FYB_RD { display:none }" document.head.appendChild(style) } let mutationObserver = window.MutationObserver let observer = new MutationObserver(hideDom) observer.observe(document, { childList: true, subtree: true })
彈窗是插件與用戶交互的界面,就像正常的html頁面同樣,不過這裏不用寫<head><body>等標籤,直接寫html代碼便可,本插件目前暫無什麼交互,因此代碼簡單明瞭,僅僅說明插件功能:github
<meta charset="UTF-8"> <div> <div style="width: 400px">歡迎使用"清新網頁"插件</div> <div> <div>插件功能以下:</div> <ol> <li>屏蔽百度推薦搜索熱點</li> </ol> </div> </div>
最後須要一個圖標文件,安裝後將會顯示在瀏覽器的右上角做爲插件的入口:web
至此,一個完整的插件就開發好了,麻雀雖小,五臟俱全,能夠搞事情了。chrome
3、插件打包
進入chrome://extensions/頁面,點擊右上角開發者模式,開啓後就會看到彈出的菜單欄,點擊打包擴展程序。json
彈出界面內須要填寫兩個地址,第一個是擴展程序根目錄(即brisk_page)。第二個是密鑰文件,第一次不用填,會生成密鑰文件,文件地址與擴展程序根目錄同級。segmentfault
點擊打包擴展程序,就會發現和brisk_page同級會生成一個crx文件,即擴展程序包:瀏覽器
4、安裝
從文件夾將此文件拖入擴展程序頁面便可安裝!不出意外,已經能夠看到效果了。
本文要介紹的內容就到此了,其實chrome插件沒有什麼技術難度,可是仍是有不少實際用途。文章只是簡單介紹了chrome插件開發的方法,文中的插件還會繼續改進,插件的github倉庫地址:https://github.com/Lushenggan...。
該插件預期是可讓用戶自由設置某個網站DOM屏蔽規則,若是您對該插件有好的想法,能夠給我提issue或者pr,不甚感激
轉載https://segmentfault.com/a/1190000019754133