亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

用VueJS寫一個Chrome瀏覽器插件的實現方法

2019-11-19 12:03:52
字體:
來源:轉載
供稿:網友

瀏覽器基本已經天下大統了,放眼望去都是Chromium的天下。那么,能寫一個瀏覽器插件也算是一種回報率不錯的技能。

基本知識

瀏覽器插件官方的說法叫擴展程序,允許你為瀏覽器增加各種功能,但不需要深入研究瀏覽器本身的代碼。你可以用HTML,CSS和JavaScript創建新的擴展程序,如果你曾經寫過網頁,那么寫一個插件是非常輕松的事情。

常見的插件一般就是地址欄后面的一個圖標,點擊后給你當前網頁提供各種功能,或者在你點擊網頁右鍵時彈出額外的菜單。

程序目錄結構

最簡單的擴展程序只需要3個文件,或者更少。

my-addon |- manifest.json |- icon.png └─ popup.html
  • manifest.json:清單文件,用來描述插件本身,必須。
  • icon.png:圖標文件,如果你不想用默認圖標這也是必須的。
  • popup.html:算是插件的功能頁吧,你至少得有點功能才有存在的意義吧。

當然上面的例子是最精簡的情況了,一般的插件會有多個html,還有js目錄,css目錄等等,你可以把插件當成一個靜態網站,唯一的區別是多了一個manifest文件用來描述這個靜態網站。

清單文件示例

下面是一個精簡版的manifest.json。

{ "manifest_version": 2, "name": "One-click Kittens", "description": "This extension demonstrates a browser action with kittens.", "version": "1.0", "permissions": [  "https://secure.flickr.com/" ], "browser_action": {  "default_icon": "icon.png",  "default_popup": "popup.html" }}

看上去是不是很直觀,名字,版本,描述,權限,行為。如果要深入再查查官方文檔就OK了。

Hello World插件

有了基礎知識,我們速度來個Hello World,先寫manifest.json。

{  "manifest_version": 2,  "name": "Hello",  "version": "1.0.0",  "description": "Hello, Chrome extension.",  "icons":  {    "16": "img/icon.png",    "48": "img/icon.png",    "128": "img/icon.png"  },  "browser_action":   {    "default_icon": "img/icon.png",    "default_title": "Hello World",    "default_popup": "popup.html"  },  "permissions":  [    "<all_urls>"  ],  "homepage_url": "https://github.com/tobyqin/"}

再補一下圖標文件和popup.html。

<!DOCTYPE html><html><body><h1>Hello world!</h1></body></html>

打開瀏覽器插件頁面,右上角打開開發者模式,加載插件目錄。

這時我們的第一個插件就好了,點擊插件圖標就可以顯示Hello World。

把Vue加進來

好像很容易嘛,我們直接用CDN的Vue,改造一下popup.html。

<!DOCTYPE html><html><body><div id="app">  {{ message }}</div><script src="https://cdn.bootcss.com/vue/2.6.6/vue.js"></script><script>  var app = new Vue({    el: '#app',    data: {      message: 'Hello Vue!'    }  })</script></body></html>

不用卸載剛才安裝的插件目錄,只要再點擊一下插件按鈕就會自動加載最新的代碼。不過好像不對,和期望的結果不一樣。

而且注意看插件頁面,出現錯誤了。

Refused to load the script 'https://cdn.bootcss.com/vue/2.6.6/vue.js' because it violates the following Content Security Policy directive: "script-src 'self' blob: filesystem: chrome-extension-resource:". Note that 'script-src-elem' was not explicitly set, so 'script-src' is used as a fallback.

Refused to execute inline script because it violates the following Content Security Policy directive: "script-src 'self' blob: filesystem: chrome-extension-resource:". Either the 'unsafe-inline' keyword, a hash ('sha256-fMtOu4CF/4bYGHZuo6ltgNQyLcxFW9rBnAYSk3yz53w='), or a nonce ('nonce-...') is required to enable inline execution.

默認情況下,瀏覽器插件權限是非常低的,不允許訪問除了插件本身的文件以外的文件,不能調用頁面內腳本(inline script),也不能使用eval之類的函數。

你需要在manifest文件中配置好Content Security Policy(CSP)才能使用Vue。

{ "manifest_version": 2, // ... "browser_action": {  // ... }, "content_security_policy": "style-src 'self' 'unsafe-inline';script-src 'self' 'unsafe-eval' https://cdn.bootcss.com; object-src 'self' ;"}

因為這個CSP寫起來實在不怎么友好,偉大的網友做了一個工具可以幫你一把。

https://github.com/foundeo/content-security-policy.com/

接下來,把頁面內的script內容搬到單獨的文件。

// popup.html<!DOCTYPE html><html><body><div id="app">  {{ message }}</div><script src="https://cdn.bootcss.com/vue/2.6.6/vue.js"></script><script src="app.js"></script></body></html>// app.jsnew Vue({  el: '#app',  data: {    message: 'Hello Vue!'  }})

刷新一下插件,搞定了。

如何調試插件

調試插件和調試一個普通的網頁一樣簡單,右鍵選擇審查元素就好了。

包括插件的配置頁面,新彈出的頁面等等,都可以用一樣的方法調試。

如何發布插件

當你完成插件開發后,在啟用開發者模式的插件中心就可以看到打包插件按鈕,這個按鈕可以幫你快速打包crx文件,第一次打包你不需要提供密鑰,它會幫你生成一個密鑰,之后的版本升級你需要用同一個密鑰打包,否則就被認為是一個新的插件了,所以切記保存好密鑰。

拿著打包好的crx文件你就可以到商店發布啦,不過發布到谷歌商店是要交錢的,一年9.9美刀的開發者會員。國內的各種商店收不收費不知道。

比較惡心的是,如果你的插件沒有在谷歌瀏覽器的商店里上架,Chrome瀏覽器是不認的,以前還可以拖到插件頁面安裝,現在怎么都繞不過去了。但基于Chromium開發的第三方瀏覽器還是可以裝的,比如Opera,QQ,360等等。

一些技巧

他山之石

可能你要做的插件別人已經做過了,或者你想借鑒別人的插件,有兩個方法。

  1. 右鍵審查別人的插件頁面,看看代碼怎么工作的。
  2. 安裝一個下載crx的插件,然后把別人的插件從商店下載到本地,重命名為zip并解壓,就可以看到源碼了。

當然啦,別人的源碼可能做過混淆加密。

插件頁面大小

如果你的插件會彈出一個頁面,瀏覽器默認會根據內容自適應頁面大小,就像上面例子里的那個hello world,很丑是吧。一般插件頁面都是限制body高度和寬度的,這樣才不會歪。

安全請求

現在很難找到不是https的頁面里,所以你的插件里如果會往后臺發送請求的話,也是需要支持https協議的,否則會被攔截的。

插件配置

如果你的插件是可配置的,怎么保存配置信息呢?直接用localStorage就行了。localStorage對每個站點都是獨立的,每一個插件可以看成獨立的站點,所以當你在插件里調用localStorage對象時就是當前插件的localStorage。如果你希望配置是可同步的,那么請考慮chrome.storage對象,里面提供了storage.local storage.sync 。

完整的例子

不想推薦文檔什么的,自己需要會去搜索的。那么有沒有一個完整的例子?當然有啦,去看我的github吧,覺得不錯就點個贊。

https://github.com/tobyqin/chrome_vue_ext_demo

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美与欧洲交xxxx免费观看| 欧美日韩国产999| 久久精品久久久久电影| 亚洲精品按摩视频| 国产精品久久激情| 97久久精品视频| 成人黄色免费看| 欧美香蕉大胸在线视频观看| 国产欧美韩国高清| 日韩免费精品视频| 91日韩在线视频| 日韩国产在线播放| 免费97视频在线精品国自产拍| 欧洲亚洲在线视频| 中文字幕日韩av| 91免费在线视频| 97人洗澡人人免费公开视频碰碰碰| 亚洲欧美色图片| 亚洲精品久久久久久久久久久| 久久97精品久久久久久久不卡| 欧美性受xxxx黑人猛交| 国产精品爽黄69天堂a| 亚洲精品久久7777777| 亚洲欧美一区二区三区在线| 亚洲综合色激情五月| www国产精品com| 久久精品国产一区二区三区| 日本亚洲欧洲色| 日韩美女在线播放| 亚洲高清久久久久久| 久久久久久久久久久av| 国产精品1区2区在线观看| 精品亚洲一区二区三区在线播放| 97不卡在线视频| 欧美精品免费在线观看| 欧美日韩xxx| 粉嫩av一区二区三区免费野| 欧美激情精品久久久久久久变态| 一本色道久久88精品综合| 亚洲xxxx做受欧美| 国产在线视频2019最新视频| 欧亚精品在线观看| 欧美性猛交视频| 日韩欧美在线字幕| 欧美激情高清视频| 亚洲福利在线视频| 久久999免费视频| 日韩av中文字幕在线免费观看| 国产精品视频一| 91网站在线免费观看| 国产精品18久久久久久麻辣| 国产欧美一区二区三区久久| 91理论片午午论夜理片久久| 亚洲一区中文字幕在线观看| 亚洲视频专区在线| 国产国语刺激对白av不卡| 色爱精品视频一区| 日本人成精品视频在线| 91精品视频在线看| 久久久久免费精品国产| www.日韩不卡电影av| 精品视频www| 欧美午夜无遮挡| 国产精品一二区| 一区二区三区天堂av| 久久手机精品视频| 国产日韩精品视频| 一区二区三区 在线观看视| 亚洲性69xxxbbb| 久久精品久久久久| 97在线精品国自产拍中文| 日韩黄色在线免费观看| 91国产在线精品| 亚洲风情亚aⅴ在线发布| 亚洲成人黄色在线观看| 久久免费视频网站| 亚洲四色影视在线观看| 国产不卡视频在线| 91免费精品视频| 伊人青青综合网站| 亚洲aaa激情| 色www亚洲国产张柏芝| 欧美日韩亚洲高清| 久久久久久久一区二区| 国产精品免费久久久久影院| 亚洲精美色品网站| 久久97精品久久久久久久不卡| 久久久国产视频91| 国产精品视频一| 在线免费观看羞羞视频一区二区| 欧美国产在线视频| 成人免费淫片视频软件| 97成人精品视频在线观看| 成人福利在线视频| 日韩视频免费在线观看| 欧美理论电影在线观看| 亚洲成色999久久网站| 亚洲天堂免费视频| 精品动漫一区二区三区| 在线播放亚洲激情| 欧美电影在线观看完整版| 尤物九九久久国产精品的特点| 亚洲japanese制服美女| 91免费看片在线| 日韩日本欧美亚洲| 色噜噜国产精品视频一区二区| 人人做人人澡人人爽欧美| 98精品国产高清在线xxxx天堂| 色多多国产成人永久免费网站| 91在线免费看网站| 日韩精品中文字幕在线观看| 久久久国产精彩视频美女艺术照福利| 国产精品自拍小视频| 亚洲老头同性xxxxx| 精品香蕉在线观看视频一| 精品国产电影一区| 欧美成aaa人片在线观看蜜臀| 久久久日本电影| 欧美大全免费观看电视剧大泉洋| 欧美性黄网官网| 亚洲自拍欧美另类| 国产欧美一区二区三区视频| 国产成人av在线播放| 久久久免费高清电视剧观看| 国产精品久久久久久久久久99| 性欧美长视频免费观看不卡| 欧美另类在线观看| 青青久久av北条麻妃黑人| 亚洲精品福利在线| 精品久久久久久中文字幕| 欧美日韩精品在线视频| 一本色道久久88综合日韩精品| 亚洲免费人成在线视频观看| 欧美国产日韩视频| 好吊成人免视频| 亚洲欧美在线一区| 黑人巨大精品欧美一区二区免费| 日韩中文字幕在线精品| 欧美大片在线看免费观看| 久久久噜噜噜久久中文字免| 亚洲aa中文字幕| 日韩电影免费在线观看| 国产精国产精品| 91久久精品国产91久久| 欧美一级电影久久| 久久6精品影院| 国产成人福利视频| 日韩电视剧免费观看网站| 国产精品激情av在线播放| 日韩av中文在线| 精品日本高清在线播放| 91精品久久久久久久久| 成人性生交大片免费观看嘿嘿视频| 亚洲黄色www网站| 亚洲免费电影一区| 亚洲精品电影网在线观看| 69久久夜色精品国产69| 欧美一区二区三区艳史| 日韩精品视频在线| 高清一区二区三区日本久| 久久久噜噜噜久久中文字免| 国产精品96久久久久久| 欧美在线视频观看| 一本色道久久综合狠狠躁篇怎么玩|