摘要:至于如何優雅地管理使用,再次祭出潘神的文章手摸手,帶你優雅的使用掘金項目的后端接口文檔我是用的進行的管理,其實有很多強大的功能,不僅僅是一個接口測試工具,接口文檔管理就是其中一個。
首先放個線上地址大家感受一下(由于后端用的是 leancloud 的免費套餐,因此可能會比較慢):
vue-data-board
P.S. 建議大家盡量自己注冊一個賬號(可以隨便填一個密碼),如果用默認的測試賬號,不要亂改東西,否則別人進來就沒得看了,因為你做的任何改動都會保存到后端數據庫里。
再放幾個 GIF 吸睛:
拖拽實現數據的查詢和可視化
向看板中添加圖表
通過拖拽自定義看板布局
也不知道為什么,公司里對數據分析、數據可視化的需求越來越多。這部分需求有的來自數據分析師(如果公司有數據分析師的話),有的來自產品、運營、開發,還有的來自公司的中層、高層領導,有的只是要把某一個表的數據導出,也有的希望能從多個維度對數據進行分析、可視化,還有的希望把多個可視化圖表整合在一個頁面中形成可視化的報表,有的是一次性的需求,有的是周期性的常態化需求,這些需求常常雜亂無章,而且數據的維度很多,交互比較復雜,可視化圖表的各種參數眾多,很難做到通用,而且很多數據較為敏感又需要嚴格的權限控制,時間一長,權限的管理又成了一個頭疼的事情,種種因素導致各種數據需求耗費了前端開發的大量精力,發量日漸稀薄。
相信很多公司都會有類似的數據需求,零散卻必須,雖然市面上也有不少產品提供了類似的數據管理功能,但是一來由于數據的敏感性,許多公司不愿意將自己的數據放到別的平臺上,二來這些數據管理的產品大多收費昂貴且功能難以定制。所以很多公司里這種數據需求就會落到前端的頭上,這些需求雖然零散甚至臨時,但是實現起來卻并不簡單,可視化的視覺效果需要各種參數去配置,而大量的數據需要驗證、清洗、轉換又使得接口調試和對接變得十分麻煩,增加了前端的工作量,也讓前端的 coding 變得十分惱人。
這時候做一個強大靈活易用的數據分析后臺就十分有用了,通過傻瓜式地拖拽生成圖表的方式,可以讓沒有數據基礎的同事也能很快上手;通過將公司的數據源整合到一起,可以方便地對數據進行管理;通過構建看板整合多個圖表,可以快速生成報表,便于查看、分享;通過用戶自定義圖表參數,可以有效地解決前端調參的痛苦。(一個十分工整的排比句,oh yeah!)
我在我司搭建數據分析后臺也將近一年了,實際上我從第一份實習開始就在接觸BI、數據相關的事情,在數據分析后臺的搭建過程中也踩了許多的坑,期間經歷了同事的各種吐槽,嘗試了各種不同的解決方案,如今雖然代碼能力不見多少提升,但是對于業務需求的雜亂無章、變幻莫測可謂多有體會。
在經歷了半年多痛苦的折磨之后,我根據業務需求,參考其他數據分析產品,搭建了全新的數據分析平臺,這一平臺如今在我司運轉良好,一方面已經滿足了一部分數據需求,另一方面也有很好的可擴展性,可以應對更復雜的業務場景。我將前端部分抽離出來,形成了這個開源項目:
dongsuo/vue-data-board
首先介紹下這個項目的基本情況,這個項目主要是用 Vue+ElementUI 搭建的,可視化部分是用的echarts,拖拽和布局部分是 vue-grid-layout 和 vuedraggable這兩個庫。這個項目一些技術、思路以及一部分輔助代碼是參考了潘神的這個后臺項目:
PanJiaChen/vue-element-admin
項目的后端部分除了少數數據是用了 mock 數據之外,都是用了 [leancloud](http://leancloud.cn) 進行搭建, Demo 數據的數據庫部分則是用了國外的一個免費數據庫 Free MySQL Hosting 速度比較慢,也沒有 root 權限,但是測試足夠用了,其他的用戶數據、圖表、看板等則是用了 leancloud 的對象存儲。
主要功能點和實現原理首先介紹項目的主要功能點及實現原理:
1. 通過拖拽字段查詢數據這個功能主要是通過構建 SQL 語句來查詢數據庫,在后端的查詢是用 Presto 來做的,Presto 可以統一查詢多種數據庫,除了傳統的關系型數據庫還可以查詢 HDFS,查詢能力比較強大。前端部分數據查詢主要是通過對 SQL 語句的解構,劃分成維度、數據、篩選、排序、數據條數等交互元素,便于沒有 SQL 基礎的用戶使用。用戶在前端的交互按照特定語法規則動態生成 SQL 發送到后端進行數據庫的查詢。當然目前 SQL 的構建功能還不完整,有一些 SQL 語法還有待支持,已經列入了開發計劃中。
2. 對數據進行可視化渲染對數據進行可視化渲染主要是通過數據查詢的維度和數值來判斷可用的圖表類型,然后利用 vue.js 的動態組件來渲染對應的圖表組件:
// Vue.js 動態組件渲染對應的圖表類型
這里有一個問題是圖表與數據的映射關系的問題,不同的數據適合用不同的圖表來展示,例如餅圖的數據跟堆疊柱狀圖的數據就不一樣,因此需要對各個圖表所需要的數據結構進行定義:
// 這是餅圖的匹配規則定義 matchRule: { desc: "1個維度1個數值;0個維度多個數值", isUsable(dimensions, calculs) { return (dimensions.length === 1 && calculs.length === 1) || (dimensions.length === 0 && calculs.length >= 1) } },
然后根據匹配規則來判斷圖表類型是否可用。
3. 圖表的保存和回顯前端生成圖表后就可以保存到后端了,由于定義一個圖表所需要的字段太多,而且這些字段還可能會經常增減改動,因此不太可能讓后端在數據庫一一定義這些字段,因此我們采用的方案是由前端來維護這些字段,后端統一將所有的內容以字符串或者 json 對象的方式存在數據庫的一個字段(如 content)中。
這樣一來圖表的回顯問題也就沒有任何問題了,按照生成圖表的邏輯把 content 字段的內容解析出來就好了。
4. 圖表整合到看板很多時候業務都需要同時查看多個圖表,這個時候就需要一個看板來整合多個圖表。看板其實是指 Dashboard,中文其實沒有很貼切的翻譯可以對應,看板勉強達意。
看板整合多個圖表在后端而言只是一個關聯關系的管理,對前端而言則需要根據看板關聯的圖表來對頁面進行布局,然后根據保存的圖表來查詢數據、可視化渲染。頁面布局主要是利用了 vue-grid-layout 進行 grid 布局,同時也支持拖拽和大小調整等。可視化的邏輯跟創建圖表時的可視化是一樣的,不再贅述。
這里遇到的問題是對于已有布局的看板,添加新圖表時,新圖表的定位要如何計算。這其實跟圖片瀑布流的問題有些相似,但是由于各個 item 不定寬高,其實相對更難一些,我已經找到了思路,做了一些計算,但是目前還不完善,完善后我會再寫文章來介紹。
5. 數據的權限問題公司的數據其實相當敏感,對于上市公司而言,數據會影響股價走勢,對非上市公司來說,會影響投融資的進度,都是關系到公司財務甚至生死存亡的大事,因此數據的權限管理是十分重要的。在這個項目里,這一部分的解決方案其實并不簡單,但是復雜度主要在于后端而不是前端。簡單來說,我們的權限是做到了數據表這一層級,由管理員向系統中添加數據源,添加的同時定義好該數據源的權限范圍,如產品、運營、開發等權限角色。用戶進入系統后,由管理員給用戶分配權限角色,用戶只能查詢其自身對應角色所能查看的數據。由于權限和數據源管理的部分暫時還沒有添加到這個開源項目中來,因此也就不細說了,先挖個坑,以后有機會再填。
6. 其他技術點:首先項目的構建是用了 Vue-cli@3.0,除了默認的配置之外,還通過 vue.config.js 做了一些自定義的配置。另外還有環境變量的配置等等,項目的配置方面建議參考潘神的這篇文章:
手摸手,帶你用vue擼后臺 系列五(v4.0新版本) - 掘金
項目中用到了很多 icon,雖然Element UI 的 icon 在2.8.x版本之后增加了不少, 但是還是不能滿足我們的需求(一些常用的 icon 仍然沒有,比如保存),因此需要自己來解決 icon 的問題,這里要感謝 iconfont 上的設計師如山提供的這套漂亮的數據可視化圖標庫。至于 icon 如何優雅地管理使用,再次祭出潘神的文章:
手摸手,帶你優雅的使用 icon - 掘金
項目的后端接口文檔我是用的 postman 進行的管理,其實 postman 有很多強大的功能,不僅僅是一個接口測試工具,接口文檔管理就是其中一個。我在開發時一般是在本地同時起前端和后端兩個項目,本地開發時通過環境變量判斷接入本地的后端接口地址:
const fetchInstance = axios.create({ baseURL: process.env.VUE_APP_BASE_API *}*)
本地開發完成后,前端打包發布到 gh-page 分支( git subtree push --prefix docs origin gh-pages ),后端通過 leancloud 提供的 cli 工具一鍵部署,還是挺方便的。前端的打包發布其實可以配置 Travis-ci 來實現自動部署,我暫時還沒有配(已棄療的拖延癥患者在此)。
項目的登錄授權、圖表和看板的增刪改查等都是使用了 leancloud 提供的解決方案,其實利用 leancloud 的 js-sdk ,前端也可以很方便地實現對象存儲的增刪改查,不需要寫后端接口。但是為了保持項目代碼的純潔,避免代碼中引入奇奇怪怪的 AV.query 這種東西,我還是自己做了后端的部分,當然這部分也做的比較簡單,畢竟只是一個 Demo,主要就是基于 koa.js 做的的一些增刪改查,基本上是面向文檔編程。
項目里的狀態管理用到了 vuex, 但是其實目前為止并沒有很多全局狀態管理的需求,只有用戶 token 保存在了 store 里。另外關于狀態管理,我在這個項目的創建圖表的部分還嘗試用了Vue 的簡單狀態管理模式( 代碼在此 ),掘金上有一篇文章介紹過這個模式:
為管理復雜組件狀態困擾?試試 vue 簡單狀態管理 Store 模式 - 掘金
這個模式用起來是沒問題的,對于大型項目里的復雜組件來說是很好用的,很方便地解決了復雜組件內部的狀態共享問題。但是目前對于我這個項目而言并不是特別適用,因為這部分的狀態管理放在全局狀態也挺合適,當然這里是見仁見智了,我覺得就目前這樣也挺好。
最后這個項目的核心功能目前算是已經完成得七七八八了,還有一些功能很不完善,后期會逐步完善起來。數據分析可視化平臺國內社區里的討論貌似不多,一些中文的討論大多是設計和產品方面的介紹,而且過于理想化,在實踐中可能不太容易落地,關于技術實現的討論不多(當然后端和運維方面還是比較多的),開源項目也沒見多少,因此我這個項目也算是做了一些探索,當然我沒多少經驗,雖然參考了幾個商業平臺的產品交互設計,但是很多地方都是摸著石頭過河,有些地方應該會有更好的解決方案,希望我的這個項目可以拋磚引玉,也希望大家能夠多提意見。
本文原創地址: 觀眾老爺們,來試試這個用 Vue 擼的數據可視化后臺吧-DongSuo
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/104834.html
摘要:背景在下前端小白,近日在刷各種算法編程題,今天碰到一編程題,考點是,雖說簡單,但在解題時發現了一個挺有意思的東東,特來分享一下。分析及結論如下原理其實很簡單,其實就是一個函數,將視為一個整體,記作。 背景 在下前端小白,近日在刷各種算法/編程題,今天碰到一編程題,考點是apply,雖說簡單,但在解題時發現了一個挺有意思的東東,特來分享一下。歡迎各位大佬指點~ 正文 話不多說,直接上題...
摘要:前言是一個優秀的前端庫,封裝了很多底層的實現,可以用來制作游戲,場景等。今年月新發布了,到今天為止已經更新到了。聲明本游戲來自于小站的官方教程,加入了一些個人的注釋,本文旨在幫助各位觀眾老爺快速上手。 前言 phaser是一個優秀的前端canvas庫,封裝了很多底層的實現,可以用來制作游戲,h5場景等。今年1月新發布了phaser3,到今天為止已經更新到了3.30。 聲明 本游戲來自于...
摘要:調試的基本步驟發現程序錯誤的存在以隔離消除等方式對錯誤進行定位確定錯誤產生的原因提出糾正錯誤的解決辦法對程序錯誤予以改正重新測試和版本的介紹通常稱為調試版本,它包含調試信息,并且不做任何優化,以便于程序員調試。 ...
摘要:作為年最具潛力,乃至最具影響力的前端開源項目真的不為過。通過上的介紹,這個項目是偏右阿里的前端大牛和阿里的前端大牛主導,而且從中也不難看出有些部分是來自參與過的項目。 showImg(https://segmentfault.com/img/bVH8b2?w=900&h=500); 在2016年,前端的開源世界越發精彩,Vue的不斷壯大,Angular 2的發布,Amaze UI 3....
閱讀 2661·2021-09-09 09:33
閱讀 2818·2019-08-30 15:54
閱讀 2876·2019-08-30 14:21
閱讀 2363·2019-08-29 17:15
閱讀 3588·2019-08-29 16:13
閱讀 2766·2019-08-29 14:21
閱讀 3433·2019-08-26 13:25
閱讀 2034·2019-08-26 12:14