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

使用node-canvas在服務端渲染echarts圖表解析

 更新時間:2022年10月11日 10:01:09   作者:元無心  
這篇文章主要介紹了使用node-canvas在服務端渲染echarts圖表解析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

踩了很長時間的坑,總算是能跑起來了

但是如果要我給echarts的SSR一個評價,那就是不好用……可能是我太菜了。而且,因為我是Windows用戶,這個過程對Windows極其不友好。

友情提示:入坑請慎重

在服務端渲染圖表,繞不開的一個問題就是,沒有DOM怎么繪圖?這個主要有兩種解決方案,一個是用那些headless的瀏覽器去渲染,然后進行截圖;另一個就是在Node環(huán)境下模擬DOM元素,比如我在這里想用canvas,就得裝個node-canvas;如果想用SVG,就得用JSDOM一類的庫。我這里主要是用的canvas,所以就用node-canvas了。

首先,需要安裝node-canvas和echarts。echarts不用多說,但是有一點,不建議使用官方推薦的node-echarts,版本陳舊,而且依賴的庫新版本的Node(12.x)不支持。

node-canvas安裝請參考官方文檔,因為安裝流程比較復雜,尤其是Windows用戶:https://github.com/Automattic/node-canvas/wiki/Installation:-Windows

當然,因為眾所周知的原因,最后一步用npm install安裝node-canvas是個問題,因為它預編譯的安裝包好像是在AWS上,大概率會卡在這里:

node-pre-gyp WARN Using request for node-pre-gyp https download

或者,還有可能卡在這里:

node-pre-gyp info install unpacking Release/
node-pre-gyp info install unpacking Release/canvas.exp
node-pre-gyp info install unpacking Release/canvas.ilk

然后還有可能直接報錯。解決方案就是,加個–build-from-source,不用他編譯好的,而是在我們本機進行編譯:

npm install canvas --verbose --build-from-source

在這個過程中,還有可能報錯,比較常見的有這些

1、找不到node-gyp。

決辦法:npm install -g node-gyp,裝一個就是了。不過一般來說會自帶才對……

2、fatal error C1083: 無法打開包括文件: “cairo.h”: No such file or directory。

解決方法:參考官方文檔安裝GTK 2,并放在合適的路徑。

3、fatal error C1083: 無法打開包括文件: “jpeglib.h”: No such file or directory

解決方法:參考官方文檔安裝libjpeg-turbo,并放在合適的路徑。

注意,對于Windows用戶,一定要安裝for VC++的版本,不要裝成for gcc的版本。

4、Error: Cannot find module '../build/Release/canvas.node'

解決方法:進入node_modules/canvas目錄,然后使用node-gyp configure build手動編譯。

5、gyp: binding.gyp not found

解決方法:同4。還有一種可能是缺少windows-build-tools,這個在第7點中說。

6、node.lib已損壞。

解決方法:升級Node版本,或者嘗試Node安裝包的repair功能。大概率是Node沒裝好,或者你使用了canvas-prebuilt這個已經(jīng)廢棄的庫。實測升級到最新版本12.16.1可以修復。

7、與windows-build-tools相關的一系列錯誤。

解決方法:npm install --global --production windows-build-tools

但是在此過程中可能會出現(xiàn)一系列問題??赡軙ㄔ谶@里:

Python 2.7.16 is already installed, not installing again.

也有可能卡在這里:

Successfully installed Python 2.7

或者提示安裝完了,但一直沒有退出,請往下看。

第一次卡住的時候,嘗試重復一遍install,如果解決了那自然最好,如果沒解決,甚至報錯:

Error: EBUSY: resource busy or locked

那么我們可能是遇到了同樣的問題。

網(wǎng)上有兩種方案,我放在這里做個參考,雖然對我來說都沒用就是了:

1、先安裝一個舊版本npm install --global --production windows-build-tools@4.0.0,然后重新npm install -g --production windows-build-tools,就可以了。

2、針對resource busy or locked的報錯,先在任務管理器里kill掉BuildTolls_Full.exe這個進程,然后去C:\Users\<你的用戶名>\.windows-build-tools里找到build-tools-log.txt,在這個文件的最后增加一行:

Variable: IsInstalled = 1

保存后重新install。

但是這兩種對我來說都沒用。后來,我無意中看到一個方法,死馬當活馬醫(yī),居然成了……說起來也很迷幻,加個–verbose就好了:

npm install --global --production --verbose windows-build-tools

到了這里,基本上就可以開始了。其實方法并不神秘,主要就是這么一個方法: 

const path = require('path')
const { createCanvas } = require('canvas')
const echarts = require('echarts')
function generateImage(options) {
  const canvas = createCanvas(600, 600) // 600 * 600的canvas
  const ctx = canvas.getContext('2d')
  ctx.font = '12px'
  echarts.setCanvasCreator(() => canvas) // 使用node-canvas
  const chart = echarts.init(canvas)
  options.animation = false
  options.textStyle = {
    fontSize: 12
  }
  chart.setOption(options) // 就是echarts的options
  return chart.getDom().toBuffer() // 返回buffer
}

這里也可以用fs.writeFileSync來進行文件讀寫,不過我更傾向于返回buffer流,個人愛好而已。

不過,返回buffer流的話,前端需要一些處理,以axios為例,需要設置responseType為blob,然后用createObjectURL來處理blob,然后把url放到img里去:

const { data } = await axios.get('/api/chart', {
    responseType: 'blob'
})
URL.createObjectURL(data) // 放進img.src的url

最終效果差不多是這樣:

同時,服務端渲染還面臨著服務端不支持中文導致亂碼,圖片不清晰等問題,這些我還沒有特別好的處理辦法,只能看情況進行處理。

我只說說我試過有用的辦法

1、針對亂碼問題,node-canvas 2.x提供了一個導入字體的方法registerFont(),可以指定中文字體。但是我并不喜歡這個方法,平白無故增加靜態(tài)資源的數(shù)量。

據(jù)說在服務器上裝好中文字體可以解決,但在我這里沒用。

2、圖片不清晰,可以在init的時候增大像素比:

echarts.init(canvas, null, {devicePixelRatio: 2});

但是這又有一個問題,這么弄出來的圖片大小會翻倍。本來我用SSR就是希望提高性能,為了清晰度還得犧牲性能,就有點本末倒置了。

總的來說,目前我還沒有發(fā)現(xiàn)對echarts進行SSR的好處,可能用那些更輕量的圖表庫配合SVG效果會比較好,比如D3??赡苡杏玫膱鼍熬褪秋@示那些對清晰度要求不太高的圖表,比如圖表的動態(tài)縮略圖,因為有時候可能會有這樣的需求,雖然是縮略圖或者是示意圖,也希望能夠動態(tài)更新,因為前后數(shù)據(jù)變化可能比較大。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

參考資料

https://github.com/Automattic/node-canvas/issues/1468#issuecomment-522961098

https://github.com/mapbox/node-pre-gyp/issues/477#issuecomment-534231739

相關文章

  • 使用Node.js搭建Web服務器

    使用Node.js搭建Web服務器

    這篇文章介紹了使用Node.js搭建Web服務器的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • 異步JavaScript編程中的Promise使用方法

    異步JavaScript編程中的Promise使用方法

    這篇文章主要介紹了異步JavaScript編程中的Promise使用方法,包含Ajax的結(jié)合操作等問題,需要的朋友可以參考下
    2015-07-07
  • socket.io實現(xiàn)在線群聊功能

    socket.io實現(xiàn)在線群聊功能

    這篇文章主要為大家詳細介紹了socket.io實現(xiàn)在線群聊功能的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • 詳解npm和cnpm混用的坑

    詳解npm和cnpm混用的坑

    有沒有遇到過npm和cnpm一起用的時候出現(xiàn)奇奇怪怪的問題呢? 有沒有遇到過cnpm在支付寶小程序上面安裝包無效?本文就詳解一下npm和cnpm混用的坑,感興趣的可以了解下
    2021-07-07
  • nodejs中使用worker_threads來創(chuàng)建新的線程的方法

    nodejs中使用worker_threads來創(chuàng)建新的線程的方法

    這篇文章主要介紹了nodejs中使用worker_threads來創(chuàng)建新的線程的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • node.js連接mysql與基本用法示例

    node.js連接mysql與基本用法示例

    這篇文章主要介紹了node.js連接mysql與基本用法,結(jié)合實例形式分析了nodejs中mysql模塊的安裝、引入、創(chuàng)建連接、sql語句執(zhí)行等相關操作技巧,需要的朋友可以參考下
    2019-01-01
  • node.js 開發(fā)指南 – Node.js 連接 MySQL 并進行數(shù)據(jù)庫操作

    node.js 開發(fā)指南 – Node.js 連接 MySQL 并進行數(shù)據(jù)庫操作

    通常在NodeJS開發(fā)中我們經(jīng)常涉及到操作數(shù)據(jù)庫,尤其是 MySQL ,作為應用最為廣泛的開源數(shù)據(jù)庫則成為我們的首選,本篇就來介紹下如何通過NodeJS來操作 MySQL 數(shù)據(jù)庫。
    2014-07-07
  • Node文件操作匯總實例詳解

    Node文件操作匯總實例詳解

    這篇文章主要為大家介紹了Node文件操作匯總實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10
  • npm?install?-g?@vue/cli常見問題解決匯總

    npm?install?-g?@vue/cli常見問題解決匯總

    這篇文章主要給大家介紹了關于npm?install?-g?@vue/cli常見問題解決的相關資料,文中通過實例代碼將解決的方式介紹的非常詳細,對遇到這個問題的朋友具有一定的參考學習價值,需要的朋友可以參考下
    2022-08-08
  • 使用nodejs寫接口的詳細步驟

    使用nodejs寫接口的詳細步驟

    這篇文章主要給大家介紹了關于使用nodejs寫接口的詳細步驟,在Node.js中接口可以采用多種形式,包括函數(shù)接口、對象接口和事件接口等,需要的朋友可以參考下
    2023-10-10

最新評論