使用 Create-React-App 開發 Chrome 擴展

整理 Kindle 標註、書籤和筆記從未如此簡單!javascript

Kindle 標註管理應用 Kindle Mate 只支持 Windows,不支持 Mac。標註只是解析個人剪貼文本文件,配合 FileReader API,寫個 Chrome 擴展解析文本文件就行了。css

初始化項目

安裝 React 腳手架 create-react-appnode

npm i -g create-react-app
複製代碼

初始化項目react

create-react-app my-clippings --typescript
複製代碼

--typescript 表示使用 typescript。強烈推薦使用 ts,Vue 3.x 使用 ts 重寫,Angular 2.x+ 只能使用 ts,ts 是大勢所趨。git

刪除 src/serviceWorker.ts 文件,用不着。github

支持 Sass

安裝 node-sass 便可。 若要支持 css modules,文件名從 index.scss 改成 index.module.scss 便可。web

npm i -D node-sass
複製代碼

讀取文件

讀取的文件是 Kindle 中的 /documents/My Clippings.txt 文件,Kindle 設置任何語言都是這個文件。只不過在不一樣語言下的顯示不同。 使用 FileReader API 能夠輕鬆讀取文本文件。正則表達式

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <title>Document</title>
  </head>

  <body>
    <input type="file" accept=".txt" id="file-upload" />
    <script> const dom = document.querySelector("#file-upload"); dom.onchange = function(event) { const file = event.currentTarget.files[0]; const reader = new FileReader(); reader.readAsText(file); reader.onload = () => { const temp = reader.result; console.log(temp); }; }; </script>
  </body>
</html>
複製代碼

解析文本

要解析的文本爲下面的格式,使用簡單的正則表達式便可解析。 根據 Kindle 設置的語言,中文與英文的格式會稍有不一樣,須要作不一樣的解析。

==========
娛樂至死 (尼爾·波茲曼)
- 您在位置 #1882-1884的標註 | 添加於 2019年6月2日星期日 上午10:07:30

古希臘哲學家在2500年之前就說過,人經常以本身的形象塑造上帝。如今,電視政治又添了新招:那些想當上帝的人把本身塑形成觀衆指望的形象。
==========
娛樂至死 (尼爾·波茲曼)
- 您在位置 #1925-1927的標註 | 添加於 2019年6月2日星期日 上午10:11:09

歷史的消失根本不須要如此殘酷的手段,表面溫和的現代技術經過爲民衆提供一種政治形象、瞬間快樂和安慰療法,可以一樣有效地讓歷史銷聲匿跡,也許還更恆久,而且不會遭到任何反對。
==========
娛樂至死 (尼爾·波茲曼)
- 您在位置 #1961-1963的標註 | 添加於 2019年6月2日星期日 上午10:14:42

自由不是靠關掉電視實現的。電視對於大多數人來講,是生活中最有吸引力的東西。咱們生活在一個絕大多數人不會關掉電視的世界裏。若是咱們不直接從電視獲得某種信息,咱們也會經過其餘人獲得它。
==========
複製代碼

配置 manifest.json

發佈 Chrome 應用須要配置 manifest.json 。 更多設置能夠查看開發文檔

{
  "name": "My Clippings", // 擴展名
  "short_name": "Clippings",
  "description": "Organizing your Kindle Highlight、Bookmark and Notes so easy.", // 描述
  "version": "0.0.6", // 版本號,每次提交到 chrome 應用中心
  "version_name": "0.0.6",
  "manifest_version": 2,
  "author": "Steve Xu",
  "browser_action": {
    // 點擊應用圖標的操做
    "default_icon": "icon-48.png",
    "default_title": "My Clippings"
  },
  "homepage_url": "https://github.com/nusr/my-clippings",
  "offline_enabled": true, // 容許離線運行
  "permissions": ["activeTab", "tabs", "storage"], // 使用的 chrome 權限
  "icons": {
    // 圖標
    "16": "icon-16.png",
    "32": "icon-32.png",
    "48": "icon-48.png",
    "64": "icon-64.png",
    "128": "icon-128.png",
    "200": "icon-200.png"
  },
  "content_security_policy": "script-src 'self'; object-src 'self';", // 容許加載的文件
  "background": {
    "scripts": ["background.js"], // 外部運行的 js
    "persistent": false
  }
}
複製代碼
// background.js
// 點擊擴展圖標,打開新的 Tag 頁面
function activeNewTab() {
  var chrome = window.chrome;
  if (!chrome) {
    return;
  }
  chrome.browserAction.onClicked.addListener(function() {
    var url = chrome.extension.getURL("index.html");
    if (window.tabId) {
      chrome.tabs.update(window.tabId, { selected: true });
    } else {
      chrome.tabs.create({ url: url }, function(tab) {
        window.tabId = tab.id;
      });
    }
  });
  chrome.tabs.onRemoved.addListener(function(tabId) {
    if (tabId === window.tabId) {
      window.tabId = null;
    }
  });
}

activeNewTab();
複製代碼

上傳到 Chrome 網上應用商店

Chrome 網上應用商店上傳地址是 chrome.google.com/webstore/de…

上傳應用須要支付 5 美圓的開發者費用。對於沒有信用卡的人來講,淘寶能夠找到相關代付途徑,或者尋求朋友幫助。

支付完成就能夠上傳應用了,一個帳號最多上傳 20 個應用。

首發 nusr.github.io/

相關文章
相關標籤/搜索