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

在Node.js中將SVG圖像轉(zhuǎn)換為PNG,JPEG,TIFF,WEBP和HEIF格式的方法

 更新時(shí)間:2019年08月22日 09:35:38   作者:瘋狂的技術(shù)宅  
這篇文章主要介紹了在Node.js中將SVG圖像轉(zhuǎn)換為PNG,JPEG,TIFF,WEBP和HEIF格式的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

介紹

你需要將SVG文件轉(zhuǎn)換為PNG、JPEG、TIFF、WEBP 和 HEIF 格式嗎?本文將指導(dǎo)你如何轉(zhuǎn)換為所有這些類型的格式。

我們將使用 Node.js 和Sharp npm 包來(lái)完成大部分繁重的工作。

目錄

  1. 安裝 Sharp Npm 包
  2. SVG 轉(zhuǎn) PNG
  3. SVG 轉(zhuǎn) JPEG
  4. SVG 轉(zhuǎn) TIFF
  5. SVG 轉(zhuǎn) WEBP
  6. SVG 轉(zhuǎn) HEIF

安裝Sharp Npm Package

首先你需要安裝 npm 包。你可以使用下面的 npm 或 yarn 命令安裝:

Npm

$ npm install sharp --save

Yarn

$ yarn add sharp

現(xiàn)在我們已經(jīng)準(zhǔn)備好開(kāi)始編寫(xiě)一些代碼并轉(zhuǎn)換圖像了!

SVG 轉(zhuǎn) PNG

對(duì)于第一個(gè)例子,我們將 SVG文 件轉(zhuǎn)換為可移植網(wǎng)絡(luò)圖形(PNG)文件格式。確保你在項(xiàng)目目錄的根目錄中有一個(gè)可用的 SVG 文件。

這是完整的代碼:

// Node.js

const sharp = require("sharp")

sharp("file.svg")
  .png()
  .toFile("new-file.png")
  .then(function(info) {
    console.log(info)
  })
  .catch(function(err) {
    console.log(err)    
  })

讓我們分解代碼的每個(gè)部分:

  1. 首先,導(dǎo)入 sharp 包并將其保存在 sharp 變量中。
  2. 然后,我們用 sharp 包來(lái)讀取我們的 file.svg 文件,將其轉(zhuǎn)換為 PNG 并使用 .toFile() 函數(shù)將新的 PNG文件寫(xiě)入你的目錄。
  3. sharp 方法是一個(gè) promise,我們用它來(lái)獲取文件的 info。
  4. 最后,我們用 .catch() 方法來(lái)捕獲并 console.log() 所有錯(cuò)誤。

當(dāng)你運(yùn)行代碼時(shí),應(yīng)該得到類似的輸出:

{
  format: 'png',
  width: 2500,
  height: 527,
  channels: 4,
  premultiplied: false,
  size: 47194
}

你應(yīng)該能夠在項(xiàng)目目錄中看到新的 PNG 文件。

還可以將其他選項(xiàng)傳遞給 .png() 方法來(lái)更改輸出圖像。這些包括壓縮級(jí)別、質(zhì)量、顏色等。你可以在文檔中查看它們。

SVG 轉(zhuǎn) JPEG

現(xiàn)在,讓我們將 SVG 文件轉(zhuǎn)換為 JPEG 格式。確保項(xiàng)目目錄的根目錄中有一個(gè) SVG 文件可供使用。

這是完整的代碼:

const sharp = require("sharp")
sharp("file.svg")
  .png()
  .toFile("new-file.jpg")
  .then(function(info) {
    console.log(info)
  })
  .catch(function(err) {
    console.log(err)
  })

當(dāng)運(yùn)行代碼時(shí),你應(yīng)該得到類似的輸出:

{
  format: 'jpg',
  width: 2500,
  height: 527,
  channels: 4,
  premultiplied: false,
  size: 47194
}

你應(yīng)該在項(xiàng)目目錄中看到新的JPEG文件。

文檔:http://sharp.pixelplumbing.com/en/stable/api-output/#png

SVG 轉(zhuǎn) TIFF

接下來(lái),讓我們將SVG文件轉(zhuǎn)換為標(biāo)記圖像文件格式(TIFF)文件。確保你在項(xiàng)目目錄的根目錄中有一個(gè)我們可以使用的SVG文件。

這是完整的代碼:

const sharp = require("sharp")

sharp("file.svg")
 .tiff()
 .toFile("new-file.tiff")
 .then(function(info) {
  console.log(info)
 })
 .catch(function(err) {
  console.log(err)
 })

當(dāng)你運(yùn)行代碼時(shí),應(yīng)該得到類似的輸出:

{
  format: 'tiff',
  width: 2500,
  height: 527,
  channels: 3,
  premultiplied: false,
  size: 65778
}

你應(yīng)該在項(xiàng)目目錄中看到新的TIFF文件。

文檔:http://sharp.pixelplumbing.com/en/stable/api-output/#tiff

SVG到WEBP

接下來(lái),將 SVG 文件轉(zhuǎn)換為 WEBP 文件格式。確保你在項(xiàng)目目錄的根目錄中有一個(gè)我們可以使用的SVG文件。

這是完整的代碼:

const sharp = require("sharp")

sharp("file.svg")
 .webp()
 .toFile("new-file.webp")
 .then(function(info) {
  console.log(info)
 })
 .catch(function(err) {
  console.log(err)
 })

輸出:

{
 format: 'webp',
 width: 2500,
 height: 527,
 channels: 4,
 premultiplied: false,
 size: 35600
}

你應(yīng)該在項(xiàng)目目錄中看到新的WEBP文件。

文檔:http://sharp.pixelplumbing.com/en/stable/api-output/#webp

SVG到HEIF

最后一個(gè)例子,讓我們將 SVG 文件轉(zhuǎn)換為高效圖像文件(HEIF)格式。確保你在項(xiàng)目目錄的根目錄中有一個(gè)可用的SVG文件。

這是完整的代碼:

const sharp = require("sharp")

sharp("file.svg")
 .png()
 .toFile("new-file.heif")
 .then(function(info) {
  console.log(info)
 })
 .catch(function(err) {
  console.log(err)
 })

你還應(yīng)該在項(xiàng)目目錄中看到新的HEIF文件。

文檔:http://sharp.pixelplumbing.com/en/stable/api-output/#png

結(jié)論

希望本文能幫助你完成編碼工作!也希望大家多多支持腳本之家。

原文:https://coderrocketfuel.com/article/convert-a-svg-image-to-png-jpeg-tiff-webp-and-heif-formats-in-node-js

相關(guān)文章

  • Node.js爬取豆瓣數(shù)據(jù)實(shí)例分析

    Node.js爬取豆瓣數(shù)據(jù)實(shí)例分析

    這篇文章通過(guò)實(shí)例給大家詳細(xì)分析了Node.js爬取豆瓣數(shù)據(jù)的過(guò)程以及具體方法步驟,有興趣的朋友可以參考學(xué)習(xí)下。
    2018-03-03
  • npm使用國(guó)內(nèi)淘寶鏡像的兩種方法

    npm使用國(guó)內(nèi)淘寶鏡像的兩種方法

    npm install時(shí)候,默認(rèn)是去npm鏡像源獲取,很多時(shí)候蝸牛一樣的速度,所以需要將安裝源設(shè)置成國(guó)內(nèi)的源,這樣速度就會(huì)快很多,本文就來(lái)介紹一下npm使用國(guó)內(nèi)淘寶鏡像的兩種方法,感興趣的可以了解一下
    2023-08-08
  • node.js操作MongoDB的實(shí)例詳解

    node.js操作MongoDB的實(shí)例詳解

    這篇文章主要介紹了node.js操作MongoDB的實(shí)例詳解的相關(guān)資料,希望通過(guò)本能幫助到大家,讓大家理解掌握這部分內(nèi)容,需要的朋友可以參考下
    2017-10-10
  • Node中的util.promisify()方法的基本使用和實(shí)現(xiàn)

    Node中的util.promisify()方法的基本使用和實(shí)現(xiàn)

    眾所周知,在JS中實(shí)現(xiàn)異步編程主要是通過(guò)以下幾種方案,回調(diào)函數(shù),觀察者模式,Generator,Promise,async / await ,今天就和大家一起聊一下在node中的一個(gè)util.promisify()這個(gè)API的基本使用和基本實(shí)現(xiàn)
    2023-07-07
  • Node.js實(shí)現(xiàn)爬取網(wǎng)站圖片的示例代碼

    Node.js實(shí)現(xiàn)爬取網(wǎng)站圖片的示例代碼

    本文將利用Node.js開(kāi)發(fā)一個(gè)小示例—爬取某圖片網(wǎng)站的圖片,文中涉及的知識(shí)點(diǎn)有https模塊、cheerio模塊、fs模塊和閉包,感興趣的可以了解一下
    2022-04-04
  • 簡(jiǎn)單聊一聊Node.js參數(shù)max-old-space-size

    簡(jiǎn)單聊一聊Node.js參數(shù)max-old-space-size

    簡(jiǎn)單的說(shuō)Node.js就是運(yùn)行在服務(wù)端的JavaScript,下面這篇文章主要給大家介紹了關(guān)于Node.js參數(shù)max-old-space-size的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-01-01
  • Node.js pipe實(shí)現(xiàn)源碼解析

    Node.js pipe實(shí)現(xiàn)源碼解析

    這篇文章主要介紹了Node.js pipe實(shí)現(xiàn)源碼解析,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-08-08
  • node.js中的console.log方法使用說(shuō)明

    node.js中的console.log方法使用說(shuō)明

    這篇文章主要介紹了node.js中的console.log方法使用說(shuō)明,本文介紹了console.log的方法說(shuō)明、語(yǔ)法、接收參數(shù)、使用實(shí)例和實(shí)現(xiàn)源碼,需要的朋友可以參考下
    2014-12-12
  • node上的redis調(diào)用優(yōu)化示例詳解

    node上的redis調(diào)用優(yōu)化示例詳解

    這篇文章主要給大家介紹了關(guān)于node上redis調(diào)用優(yōu)化的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-10-10
  • Node.js五大應(yīng)用性能技巧小結(jié)(必須收藏)

    Node.js五大應(yīng)用性能技巧小結(jié)(必須收藏)

    本篇文章主要介紹了Node.js五大應(yīng)用性能技巧小結(jié)(必須收藏),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家
    2017-08-08

最新評(píng)論