如何使用前端技術開發一個桌面跨端應用

本文將會講述一個完整的跨端桌面應用 代碼畫板 的構建,會涉及到整個軟件開發流程,從開始的設計、編碼、到最後產品成型、包裝等。php

本文不只僅是一篇技術方面的專業文章,更會有不少產品方面的設計思想和將技術轉換成生產力的思考,我將結合我本身的使用場景徹底的講解整個開發流程,固然涉及到設計方面的不必定具備廣泛實用性,多數狀況下都是我本身的一些喜愛,我只關心本身的需求。css

同時本文只從總體上講思路,也會有個別的技術細節和常規套路,有興趣的也能夠直接去 github 上看 源碼,文章會比較長,若是你只想知道一些拿來即用的「乾貨」,或許這篇文章並非一個好的選擇html


1、定位需求

事情的原由是這樣的,由於咱們內部會有一些培訓會議。會常常現場演示一些代碼片斷。好比說咱們講到 React 的時候會現場寫一些組件,讓你們能直觀的感覺到 React 的一些功能。前端

可是一般因爲條件所所限,會議總會遇到一些意外。好比斷網、投影分辨率低看不清文字等node

起初咱們用的是在線版的 codepen,可是感受並非那麼好用。好比不能方便的修改字體大小,必需要在連網的狀況下才能使用。另外它的 UI 設計不是很緊湊,一般咱們展現代碼的時候都投影是寸土寸金的,應該有一個簡潔又不失功能的 UI 界面,能全屏展現…react

因而我解決本身實現一個這樣的輪子,那麼大概的需求目標是有了:webpack

  1. 離線可用
  2. 能夠改變界面字體大小
  3. 更加簡潔的 UI

2、總體設計

應用風格

代碼畫板解決的是 臨時性 的一些 演示代碼 的需求,因此它的本質屬性是一個拿來即用的工具,它不該該有更復雜的功能,好比用戶登陸、代碼片斷的管理等。這些需求不是它要解決的。代碼畫板會提供一個簡單的導出成 HTML 文件的功能,能夠方便用戶存儲整個 HTML 文件。git

既然是用來演示代碼的,那麼它的界面上應該只有兩個東西,一個是 代碼,一個就是 預覽。像代碼/控制檯切換的功能都作成 tab 的形式,正常狀況不須要讓他們展現出來。像 codepen 那樣把全部的代碼編輯器功能都展現出來我認爲是不對的。程序員

codepen-demo

codepen 的界面給人感受很是複雜,有不少功能點。固然我並非在批評它,codepen 作爲一個須要商業化運營的軟件,勢必會作的很是複雜,這樣才能知足更多用戶的需求。然而程序員寫軟件則能夠徹底按照本身的想法來,哪怕這個應用只給本身一我的用呢。es6

hello-code-sketch

桌面應用的設計

桌面應用的設計和 web 界面的設計仍是有些細微區別的,一樣的基於 electron 的應用,有的應用會讓人感受很「原生」,有的則一眼就能看出來是用 CSS 畫的。我在設計代碼畫板的時候也儘可能向原生靠近,避免產生落差感。好比禁用鼠標手型圖標、在按鈕或者非可選元素上禁止用戶選擇:

cursor: default;
user-select: none
複製代碼

由於實際上用戶在使用一款應用的時候感性的因素影響佔很大一部分,好比說有人不喜歡 electron 可能就是由於看到過 electron 裏面嵌一個完整的 web 頁面的操做,這就讓人很反感。可是這不是 electron 的問題,而是應用設計者的問題。

應用標識的設計

說實話應用 logo 設計我也是業餘水平,可是聊勝於無。既然水平不行,那就儘可能設計的不難看就好了。能夠參考一些好的設計。我用 sketch 畫出 logo 的外形,sketch 有不少 macOS 的模塊能夠從網上下載下來,直接基於模板修改就能夠了。

代碼畫板主要的界面是分割開的兩個面板,左邊是代碼,右邊是預覽。因此我就大概畫了一個形狀

code-sketch-icon

這個 logo 有個問題就是線條過多,小尺寸的時候看不清楚。這個問題我暫時先忽略了,畢竟我還不是專業的,後續有好的創意能夠再改

默認設置

代碼畫板也 不會有 設置界面,由於經常使用的設置都預約義好了,你不須要配置。頂多改變下代碼字體的大小。使用編輯器的通用快捷鍵 command++/- 就解決了,或者插入三方庫,直接使用編輯器的通用命令快捷鍵 command+p 調出。咱們的思路就是把複雜的東西幫用戶隱藏在後臺,觀衆只須要關注演員臺上的一分鐘,而沒必要了解其它細節。

快捷鍵/可用性

因爲代碼畫板的界面很是簡單,在一些細小的必要功能就得添加一些快捷鍵。好比:切換 HTML/CSS/JS/Console 代碼編輯器,我在每一個 tab 上加了數字標號,暗示它是有順序有快捷鍵的,並且這個切換方式和 Chrome tab 切換的邏輯一致,使用 command+數字 就能夠實現,萬一仍是有人不會用的話,能夠去看幫助文檔。裏面有全部的快捷鍵。

cs-tab

界面中間的分割條能夠自定義拖動,雙擊重置平分界面

cs-spliter

剛開始的時候我把每一個 tab 頁籤都分割成單獨的面板,由於我以爲這個能拖動自定義面板大小的交互實在是太爽了,忍不住想去拖動它。可是後來想一想,其實並無必要,咱們寫代碼時應該更專一於代碼自己,若是隻有兩個面板,那麼這個界面不管是認知仍是使用起來就沒有任何困難。

由於咱們並不須要把一堆的功能的界面摔給用戶,讓他們本身去選擇。

3、技術調研

實現控制檯

經過使用流行的幾款在線代碼運行工具,我發現他們有一個共同的問題:控制檯很難用。沒法像 Chrome Console 那樣展現任意類型的 JS 值。好比我想 log 一段嵌套的 JS 對象:

console.log({ a: { b: 1, c: { d: [1, 2, 3] } }})
複製代碼

大多數都展現成這樣的:

[object Object] {
  a: [object Object] {
    b: 1
  }
}
複製代碼

Chrome 是這樣的:

chrome-console

顯然 Chrome 控制檯中更直觀。因此咱們須要在前面的基礎上加一個需求,即:實現一個基於 DOM 的日誌展現界面(無限級聯選擇)

日誌界面應該有下面這些功能:

  1. 展現任意 JS 類型的數據
  2. Primitive 類型的數據顯示不一樣的顏色(number - 藍色,string - 綠色)
  3. Object 類型默認摺疊起來,點擊按鈕展現子級,屬性過多須要展現縮略信息
  4. 數組前應該有長度標記
  5. 能展現 JS 運行時的報錯 Error 信息

集成現代化的前端框工做流

現代化的前端寫頁面確定不是 HTML/CSS/JS 一把梭了,至少應該有 Sass/Babel 的支持吧。

Sass 嵌套能讓你少寫不少選擇器,固然 Less 也能夠,可是在咱們的這個應用裏面區別不大,通常來講臨時性的寫一些代碼不多會用到它們的細節功能。有 變量 和 選擇器 嵌套就夠了

Babel 主要是解決了寫 React 的問題,不用再安裝一大堆的構建工具了,直接使用 UMDReact/ReactDOM 就能夠了,並且 electron 內嵌的 chromium 也支持了 es6 的 class 寫法,實際上 Babel 主要的目的仍是用來轉譯 JSX

注意這裏是有一個我認爲是 剛性 的需求,好比臨時突然有個想法,或者想驗證一段代碼的話,正常狀況是使用你的編輯器,新建 demo.html/demo.css/demo.js 等這些操做。可是這些動做太浪費時間了。有了代碼畫板之後,直接打應用就能夠開始 coding 了,真正能作到開箱即用。

提升程序的擴展性

咱們在寫 demo 頁面時一般是要引用不少第三方類庫的,好比:Bootstrp/jQuery 等。我但願有一種方法能夠方便的引用到這些庫,直接把庫文件的 link/script 標籤插入到代碼畫板的 HTML 中,可是前端框架真的是太多了,又不能一個個去扣來寫死到頁面,就算是寫死了隨着框架版本的升級,可能就沒法知足咱們的需求。

之前寫頁面時常常會用到 bootcdn,無心中發現它提供了相關 API,能夠直接拿來使用。接下來就得想辦法讓用戶經過界面選擇便可。

這個 API 有三層數據結構:庫 - 版本 - 資源連接。這個功能要用界面來實現確定會很是臃腫,界面上可能會放不少按鈕。這就違背了「更簡潔」的需求目標。

這時就得參考下咱們常用的一些軟件是如何解決 簡潔性 和 功能性 需求之間的矛盾問題的,我比較喜歡 Sublime Text 的一些界面設計,Command Palette 是我常用的,因此我決定再模擬一個 Command Palette 來實現插入第三方庫的需求。並且重要的是這個 Command Palette 並不必定只用來實現這一個功能,或者後期會有一些別的功能須要添加,那這個 Command Palette 也是個很好的入口。

Command Palette

使用 electron 實現桌面應用

實現離線可用不少方法,好比使用 PWA 技術。可是 PWA 並不能給我帶來一種原生應用的那種可靠感,相反 electron 恰好能夠解決個人顧慮。同時它能夠把你的應用打包成各個平臺(macOS/Window/Linux)的原生應用。惟一的缺點就是安裝包確實很大,通常來說一個 electron 應用 安裝完 至少要 100 多兆,不過我以爲還能接受,畢竟硬盤存儲如今已經很廉價了。

有人可能對 electron 有抗拒,以爲 electron 應用太龐大、佔系統資源什麼的,不過咱們作的這個應用並不須要常駐系統,臨時性的使用一下,用完就關閉,正常寫生產環境的代碼確定仍是要換回 編輯器/IDE 的。同時由於 electron 下降了寫桌面應用的門檻,確實有不少人把一個完整的在線的網頁直接嵌進去,這也是有問題的。

electron 還有一個好處,由於它徹底基於 HTML/CSS/JS 來實現 UI(可使用 Chrome only 的一些新功能),那咱們理論上能夠在作桌面應用時順手把 web 應用也作了。這就能夠同時支持各個系統下的原生應用,而且有 web 在線版本。若是你不肯意使用原生應用,直接登陸 web.code-sketch.com 使用在線版也沒是一種選擇。這樣就使得咱們的應用具備真正的 跨端 能力。

因爲咱們團隊都使用了 macbook,因此我優先支持 macOS 的開發,另外 macOS Mojave 的系統級別的暗色主題我也比較喜歡,恰好實現支持 mojave 暗色主題這個需求也作上。

3、框架的選擇

大方向肯定了,像框架選擇這個就簡單了,基於 electron 的應用,須要你區分開 render/main process 來選擇。

Render process

渲染進程 就是 electron 中界面的實現部分 ,通常來講就是一個 webview,選本身喜歡的框架便可。我使用 React 來實現界面。樣式方面就再也不使用框架了,由於咱們的界面原則上沒有複雜的元素,直接手寫 CSS,300 行內基本上就能夠解決問題。可能有人會以爲這不可能,實際狀況是當你寫樣式只跑在 Chrome 裏面的時候那感受徹底爽到飛起,CSS variable/flex/grid/calc/vh/rem 什麼的均可以拿來用,實現一個功能的成本就下降了不少。

我使用 Codemirror 來作爲主界面的代碼編輯器,Monaco 也是一個好選擇,可是它有點過於龐大了,並且若是想要自定義功能得本身寫不少實現

主界面上的分割組件,使用了 React-split

Main process

主進程 就是 electron 應用程序的進程,主要的區別在於主進程中能夠調用一些與原生操做系統交互的 API,好比對話框、系統風格主題等。而且有 node 的運行時,能夠引用 NPM 包。固然渲染進程也能夠有 node 支持,可是我建議渲染進程中就只放一些純前端的邏輯,這樣的話方便後期把應用分離成 web 版

由於咱們要集成 Sass 編譯功能,若是你也經歷過 node-sass 的各類問題,那就應該果斷選擇 dart-sass — 使用 dart 實現,編譯成了原生的 JS,沒有依賴問題。dart-sass 我放在了 main process 中,由於我試過放在 render process 中會有各類報錯。若是 web 端要實現這個功能就須要其它的解決辦法了,好比作成一個 http 服務,讓 web 調 http 服務。

Babel 的話我是放在了 渲染進程 中以 script 標籤的方式調用,這樣即便在 web 端 Babel 編譯也是可用的。

總之若是你使用 electron 構建應用而且引入的第三方 NPM 包能夠 支持 運行在客戶端(瀏覽器)上,那就儘可能把包放在渲染進程裏面。

構建工具

我使用 Parcel 來構建 React 而不是 Create React App。後者用來寫個小應用還能夠,稍微大一點的,須要定製化一些東西你就得 eject 出來一大堆 webpack 配置文件,即使是我已經用 webpack 開發過幾個項目了,可是說實話我仍是沒用會 webpack。寫 webpack 配置的時間足夠我本身寫 npm script 來知足本身的需求了。

原生應用打

使用 electron-builder 來打包到平臺原生應用,而且若是你有 Apple 開發者帳號的話應用還能夠提交到 AppStore 上去。

我目前的打包參數是這麼配置的:

{
    "build": {
        "productName": "Code Sketch",
        "extends": null,
        "directories": { "output": "release" },
        "files": [
            "icon.icns",
            "main.js",
            "src/*.js",
            "全部須要的文件",
            "package.json",
            "node_modules/@babel",
            "node_modules/sass"
        ],
        "mac": {
            "icon": "icon.icns",
            "category": "public.app-category.productivity",
            "target": [ "dmg" ]
        }
    }
}
複製代碼

在你的 package.json 中添加 build 字段,productName, directories 這些按本身須要更改便可

4、分離開發環境

區分開開發環境

代碼畫板項目開過過程當中涉及兩個關鍵環境

  1. Parcel 構建環境(渲染進程):Parcel 能夠爲你提供一些如今 JS 的轉譯工做,所以你能夠放心使用例如 ES6 的 JS 新特性
  2. Node.JS 運行環境(主進程+渲染進程):這個取決於你的 electron 版本中集成的是 node 版本,好比:Node 10 中就沒有 ES Module,這意味着你若是要在 electron 主進程 是沒法識別 import 這樣的語句的,可是渲染進程因爲你使用了 Parcel 編譯,則無需考慮

這裏舒適提示下:想要作到 electron 中的 渲染進程與主進程之間共享 JS 代碼是很是困難的。就算是有辦法也會特別的彆扭,個人建議是儘可能分離這兩個進程中的代碼,主進程主要作一些系統級別的 API 調用、事件分發等,業務邏輯儘可能放在渲染進程中去作

若是非要共享,那建議單獨作成一個 NPM 包分別作爲主進程運行時依賴,和渲染進程的 Parcel 編譯依賴,惟一的缺點就是實際上共享的代碼會有兩份。

渲染進程中調用 node API 可能會和 Parcel 打包工具衝突,通常在調用好比文件模塊時,能夠加上 window.require(‘fs’) 這樣就能夠兼容兩個環境:

get ipc() {
    if (window.require) {
        return window.require('electron').ipcRenderer
    } else {
        return { on() {}, send() {}, sendToHost() {} }
    }
}
this.ipc.send('event', data)
複製代碼

這樣的話你在瀏覽器端調試也不會產生報錯。通常狀況下,建議當你用渲染進程中的 JS 引用(require)包的時候都加上 window. 前綴就能夠了。由於渲染進程中 window 是全局變量,調用 require 和調用 window.require 是等價的

開發流程

一般在測試的時候應用會調用一些 electron 內置的系統級別 API,這部分調用一般須要啓動 electron,可是有時候只有渲染進程中 UI 界面上的改動,就不用再啓動 electron 了,直接在瀏覽器裏面測試便可。使用 Parcel 運行一個本地的服務,這樣就能夠在瀏覽器裏面調試頁面。整個開發過程須要兩個命令(NPM Script):

啓動 Parcel 編譯服務器

"scripts": {
    "start": "./node_modules/.bin/parcel index.html -p 2044"
}
複製代碼

調試 electron 原生功能,注意設置 ELECTRON_START_URL

"scripts": {
    "dev": "ELECTRON_START_URL=http://localhost:2044 yarn electron",
}
複製代碼

技術難點

整個應用只有兩個功能是須要咱們本身寫代碼實現的:日誌控制檯,Sublime 命令行。咱們分別來分析下這兩個模塊的難點。

日誌控制檯 的難點在於,咱們須要打印任意類型的 JS 值。若是你對 JS 瞭解比較多的話天然會想到在 JS 中全部的東西都是 對象,即 Object,那麼實際上當你想打印一個變量的時候,其實你只要把整個 Object 遞歸的遍歷出來,而後作成一個無限級的下拉菜單就能夠了。看起來大概想下面這樣:

logger

Sublime 命令行 實際上開發起來仍是比較簡單的,使用 React 很簡單就實現了功能,比較麻煩的是調用 bootcdn 的接口,過程當中我發現接口返回數據量仍是挺大的,有必要作上一層 localStorage 緩存,加快二次打開速度。

然而在使用的過程當中你會發現當我想插入一個前端庫須要不少操做,由於有 三級選擇:庫-版本-CDN 連接。雖然這個流程解決了 全部用戶 的使用問題,可是卻損害了 大部分 用戶的體驗。這個時候插入一個經常使用庫的成本就很高了,因此咱們就要加上一些快捷入口,來實現一鍵插入流行框架。

sublime-commend-p

咱們寫代碼的思路是知足全部用戶的使用需求,可是一個好產品的思路是先知足大多數用戶(80%)的常規需求,再讓其他的用戶(20%)能夠有選擇

還有一個問題比較典型就是 React 這類框架在渲染大列表而且進行過濾(關鍵字查詢)時性能的問題。注意這個性能問題 並非 引入框架產生的,真正的緣由是當你渲染的 HTML 節點數以千計的時候,批量操做 DOM 會使得 DOM Render 特別慢。

因此說當咱們遇到性能問題的時候應該去查找問題的根源,而不是停留在框架使用上,實際上在 DOM 操做這個層面來說 jQuery 提供了更多的性能優化,好比自身的緩存系統,以至於當你在使用的時候很難發現有性能問題。可是在類 React 框架中它們框架自己的重點並不在於解決你應用的性能問題。

相似咱們上面講到的,實際上 jQuery 幫助你屏蔽了不少舞臺背後的東西,以至於你能夠不用操心技術細節,你甚至能夠把 jQuery 當作一個 產品 來使用,而類 React 框架你卻要親力親爲的用他來設計你的代碼。

話題再轉回性能問題。這時候須要咱們去實現一個相似於 react-window  的功能,讓列表元素根據滾動按需加載。這多是一種通用的解決大列表加載的方案,可是個人解決方法更粗暴,由於咱們的下拉過濾功能使用時用戶只關注 最佳的匹配項 便可,後面匹配程度不高的項能夠直接限制數量裁剪就好了嘛。不多有用戶會一直滾動到下面去查找某個選項,若是有,那就說明咱們這個匹配作的有問題。

slice() {
    const idx = (this.props.itemsPerPage || 50) * (this.state.activeFrame + 1)
    return this.props.items.slice(0, idx)
}
複製代碼

整個匹配篩選的狀態大概是這樣的:

this.state = {
    // 當前第N步選擇
    step: 0,
    // 當前步驟數據
    items: [],
    // 是否顯示
    active: false,
    // 當前選中項
    current: {},
    // 過濾關鍵字
    keyword: ''
}
複製代碼

這個 items 是當前步驟的全部數據,實際上咱們這個組件是支持無限級的擴展的,那麼咱們經過組件的 props 傳入全部層級的數據,而後持久存儲在內存中。這個 全部層級的數據 是數據結構層面的,實際上它多是經過異步接口獲取的。

再來看看咱們組件提供的全部 props

static defaultProps = {
    step: 0,
    active: false,
    data: [[]],    // 無限層級數據 [[], [], [], ...]
    // 數據的主鍵,用於鉤子函數返回用戶選擇的結果集
    pk: 'id',

    autoFocus: true,
    activeCls: 'active',
    delay: 300,
    defaultSelected: 0,
    placeholder: '',
    async: false,
    alias: [],
    done: () => {}
}
複製代碼

這些數據均可以經過組件的 props 傳入,這就意味着咱們的這個組件纔是真正的組件,別人也可使用這樣的功能,而他們並不用在乎裏面的細節,使用者只須要作好相似調用本身接口的這種業務邏輯。

組件的調用大概是這樣的:

<CommandPalette step={0}
    key="CommandPalette"
    async={injectData}
    done={this.done.bind(this)}
    alias={alias}
    aliasClick={this.aliasClick.bind(this)}
    data={[ [], [], [] ]}
複製代碼

async 這個 props 其實是一個異步調用的鉤子方法,它會回傳給你組件上當前操做的相關數據狀態,經過這些數據使用者就能夠按本身的需求在不一樣的步驟上調用不一樣的方法

export const injectData = (step, item, results, cb) => {
    const API = 'https://api.bootcdn.cn/libraries'

    if (step === 0) {
        fetchData(`${API}.min.json`)
            .then(processLibraryData)
            .then(cb)
    } else if (step === 1) {
        // ...
    } else if (step === 2) {
        // ...
    }
}
複製代碼

另外關於 React 這裏安利下本身翻譯過的一個教程:React 模式,裏面講到 18 種短小精悍的 React 模式案例,很是簡單易懂。

還有一個小竅門,咱們在適配暗色主題時,傳統的方法是直接寫兩套主題 CSS 代碼,實際上咱們要使用 CSS Variable 的話徹底不必生成兩套了,背景色,字體都作成 CSS 變量,切換的時候只須要動態往頁面插入更新過的 CSS 變量值便可

系統的一些參數想直接傳給渲染進程也是比較麻煩的,個人作法是直接從主進程中的 loadUrl 方法上以 queryString 的方式傳到渲染頁面的 URL 上

const query = {
    theme: osTheme,
    app_path: app.getAppPath(),
    home_dir: app.getPath('home')
}

mainWindow.loadURL(process.env.ELECTRON_START_URL ? url.format({
    slashes: true,
    protocol: 'http:',
    hostname: 'localhost',
    port: 2044,
    query
}) : url.format({
    slashes: true,
    protocol: 'file:',
    pathname: path.resolve(app.getAppPath(), './dist/index.html'),
    query
}))
複製代碼

像程序運行時的一些參數(好比程序的根目錄)也能夠這麼動態傳過去,並且還有一個好處就是你甚至能夠在渲染進程中測試與這些參數相關的功能。

5、宣傳

demo 視頻錄製

我會把最終全部功能的使用方法錄製成一個視頻,萬一有人不不想下載你的軟件,只是要了解一下,這就是個很好的方法。我同時上傳到了 Youtube 和 bilibili 這兩個平臺,其它的都有廣告就不必了

使用 Quicktime Player 便可,錄製完使用 iMovie 轉碼成兩倍速率的 mp4。若是你有興趣還能夠加上一段音樂什麼的,讓視頻看起來更靈動

域名申請

域名是一個能讓用戶記住你產品的方法,若是你作的是一個成型的產品,那就必定要申請個域名。

我老是有這樣的體驗,有的時候看到一個很是不錯的產品但因爲當時沒需求就忽略了,想起來或者忽然有需求的時候缺記不起來名字叫什麼了。

事實上代碼畫板最開始我給他起的名字是 code playground,這個更直觀,可是名字太長,並且想用到的一些域名呀、Github 名、NPM 包都被註冊了。

想來想去就換成了 code sketch,這和符合咱們的設計初衷,即:一邊是代碼,一邊是效果/草圖

域名申請我通常會上 Godaddy,不用備案,.com 域名一年 ¥65.00,而後 DNS 服務器轉到了 cloudflare,後續域名也會直接轉到 cloudflare。由於聽說之後在 cloudflare 上續費域名最便宜

網站搭建

宣傳網站直接放在 github pages 上,作個自定義域便可,實在是太方便了。並且還有 SSL 支持,Github 真的是業界良心

web 版的代碼畫板,因爲咱們把渲染進程中的代碼分離開發,因此直接把 parcel 打包出來的靜態文件也作成 github pages 就能夠了,爽歪歪,網站就等於一分錢不花了。後續作一些 web 版的加強功能時,能夠作成先後端分離的 http 服務,這就是後話了

加入 Google analytics 代碼

GA 可讓你瞭解網站的用戶分佈狀況,清楚的知道網站訪問的波動。好比說你把本身的連接放到某個網站上分享了,GA 裏面就能看出來全部的推薦來源和波動,對於運營來講是很是有必要的

廣告語

這個我還真想了好長時間,基於我對於代碼畫板的定義,我以爲它應該是一個咱們有一個想法的時候須要快速去實現一個 demo 的地方,想來想去就定了一段看起來文鄒鄒的話,雖然聽名字根本不知道它是幹啥用的,可是不要緊,程序員寫東西就是要有個性,由於個人受衆只有本身。

First place where the code was written... 一個你最初寫代碼的地方...

6、彙總使用到的庫與工具

麻雀雖小,五臟俱全。咱們來看下代碼畫板總共用到了多少東西:

  • 框架/庫
    • electronjs
    • react
    • babeljs
  • NPM 模塊
    • codemirror 及其插件
    • react-split
    • sublime-command-palette
  • 打包/工具
    • parceljs
    • electron-builder
    • bootcdn
  • 設計與素材

7、結語總結

實事上我本身的開發這個應用的時候並無嚴格按照這篇文章的順序執行,而是想到一些實現一些,可能一個功能實現了後來以爲很差又幹掉了,是不斷的取捨、提煉的結果。

開發中我也不斷的問本身這個功能是否有必要,若是無關緊要那是否是能夠去掉,這樣才能使得用戶更加關注於代碼自己。

整個開發過程當中本身實現的功能模塊並很少,只有控制檯、命令行窗口是本身實現的,其它的功能基本上都是靠社區現有的工具庫來完成的,從這一點來講前端技術的生態仍是挺好的。這使得當我從總體上構思一個產品時我沒必要在乎那些細節,雖然過程當中仍是能感受到前端工具/庫的割裂感,可是總體而言仍是向好的,畢竟工具對於開發者只是一種選擇的。

8、引用

  1. github.com/keelii/code…
  2. www.tweaknow.com/appicongene…
  3. benschwarz.github.io/gallery-css…
  4. addyosmani.com/blog/react-…
  5. github.com/keelii/reac…
  6. keelii.com/2019/03/14/…
相關文章
相關標籤/搜索