欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

用VueJS寫一個(gè)Chrome瀏覽器插件的實(shí)現(xiàn)方法

 更新時(shí)間:2019年02月27日 15:23:32   作者:betacat  
這篇文章主要介紹了用VueJS寫一個(gè)Chrome瀏覽器插件的實(shí)現(xiàn)方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

瀏覽器基本已經(jīng)天下大統(tǒng)了,放眼望去都是Chromium的天下。那么,能寫一個(gè)瀏覽器插件也算是一種回報(bào)率不錯(cuò)的技能。

基本知識

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

常見的插件一般就是地址欄后面的一個(gè)圖標(biāo),點(diǎn)擊后給你當(dāng)前網(wǎng)頁提供各種功能,或者在你點(diǎn)擊網(wǎng)頁右鍵時(shí)彈出額外的菜單。

程序目錄結(jié)構(gòu)

最簡單的擴(kuò)展程序只需要3個(gè)文件,或者更少。

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

當(dāng)然上面的例子是最精簡的情況了,一般的插件會有多個(gè)html,還有js目錄,css目錄等等,你可以把插件當(dāng)成一個(gè)靜態(tài)網(wǎng)站,唯一的區(qū)別是多了一個(gè)manifest文件用來描述這個(gè)靜態(tài)網(wǎng)站。

清單文件示例

下面是一個(gè)精簡版的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"
 }
}

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

Hello World插件

有了基礎(chǔ)知識,我們速度來個(gè)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/"
}

再補(bǔ)一下圖標(biāo)文件和popup.html。

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

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

這時(shí)我們的第一個(gè)插件就好了,點(diǎn)擊插件圖標(biāo)就可以顯示Hello World。

把Vue加進(jìn)來

好像很容易嘛,我們直接用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>

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

而且注意看插件頁面,出現(xiàn)錯(cuò)誤了。

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.

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

你需要在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' ;"
}

因?yàn)檫@個(gè)CSP寫起來實(shí)在不怎么友好,偉大的網(wǎng)友做了一個(gè)工具可以幫你一把。

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

接下來,把頁面內(nèi)的script內(nèi)容搬到單獨(dú)的文件。

// 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.js

new Vue({
  el: '#app',
  data: {
    message: 'Hello Vue!'
  }
})

刷新一下插件,搞定了。

如何調(diào)試插件

調(diào)試插件和調(diào)試一個(gè)普通的網(wǎng)頁一樣簡單,右鍵選擇審查元素就好了。

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

如何發(fā)布插件

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

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

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

一些技巧

他山之石

可能你要做的插件別人已經(jīng)做過了,或者你想借鑒別人的插件,有兩個(gè)方法。

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

當(dāng)然啦,別人的源碼可能做過混淆加密。

插件頁面大小

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

安全請求

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

插件配置

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

完整的例子

不想推薦文檔什么的,自己需要會去搜索的。那么有沒有一個(gè)完整的例子?當(dāng)然有啦,去看我的github吧,覺得不錯(cuò)就點(diǎn)個(gè)贊。

https://github.com/tobyqin/chrome_vue_ext_demo

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue路由回退的完美解決方案(vue-route-manager)

    Vue路由回退的完美解決方案(vue-route-manager)

    最近做了一個(gè)vue項(xiàng)目關(guān)于路由場景的問題,路由如何回退指定頁面,在此做個(gè)記錄,這篇文章主要給大家介紹了關(guān)于Vue路由回退的完美解決方案,主要利用的是vue-route-manager,需要的朋友可以參考下
    2021-09-09
  • vue中v-mode詳解及使用示例詳解

    vue中v-mode詳解及使用示例詳解

    這篇文章主要介紹了vue中v-mode詳解以及具體的使用示例,在組件中使用?v-model?時(shí),需要定義model選項(xiàng),指定綁定的prop和事件,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2024-03-03
  • vue全局掛載實(shí)現(xiàn)APP全局彈窗的示例代碼

    vue全局掛載實(shí)現(xiàn)APP全局彈窗的示例代碼

    本文主要介紹了vue全局掛載實(shí)現(xiàn)APP全局彈窗的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • 在vue里使用codemirror遇到的問題

    在vue里使用codemirror遇到的問題

    這篇文章主要介紹了在vue里使用codemirror遇到問題,本文給大家記錄下來了,需要的朋友可以參考下
    2018-11-11
  • vue 使用鼠標(biāo)滾動加載數(shù)據(jù)的例子

    vue 使用鼠標(biāo)滾動加載數(shù)據(jù)的例子

    今天小編就為大家分享一篇vue 使用鼠標(biāo)滾動加載數(shù)據(jù)的例子,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • Vue-cli-webpack搭建斗魚直播步驟詳解

    Vue-cli-webpack搭建斗魚直播步驟詳解

    斗魚直播是比較火的直播視頻,想必大家都看過吧。這篇文章主要介紹了Vue-cli-webpack搭建斗魚直播步驟詳解,需要的朋友可以參考下
    2017-11-11
  • ElementUI中el-tree節(jié)點(diǎn)的操作的實(shí)現(xiàn)

    ElementUI中el-tree節(jié)點(diǎn)的操作的實(shí)現(xiàn)

    這篇文章主要介紹了ElementUI中el-tree節(jié)點(diǎn)的操作的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • Vue響應(yīng)式原理及雙向數(shù)據(jù)綁定示例分析

    Vue響應(yīng)式原理及雙向數(shù)據(jù)綁定示例分析

    這篇文章主要為大家介紹了Vue響應(yīng)式原理及雙向數(shù)據(jù)綁定的示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • vue項(xiàng)目使用electron進(jìn)行打包操作的全過程

    vue項(xiàng)目使用electron進(jìn)行打包操作的全過程

    我們都知道Electron項(xiàng)目分為了主進(jìn)程和渲染進(jìn)程,主進(jìn)程其實(shí)就是我們的Electron,渲染進(jìn)程就相當(dāng)于我們的Vue項(xiàng)目,下面這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目使用electron進(jìn)行打包操作的全過程,需要的朋友可以參考下
    2023-03-03
  • 項(xiàng)目開發(fā)中husky的使用詳解

    項(xiàng)目開發(fā)中husky的使用詳解

    這篇文章主要為大家介紹了項(xiàng)目開發(fā)中husky的使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11

最新評論