Table des matières
1. Introduction au contenu
2. Au début, j'avais prévu d'utiliser l'API de pour réaliser la compression d'image. , mais après l'avoir essayé, j'ai découvert que la vitesse de compression était extrêmement lente et semblait coûter de l'argent, alors j'ai abandonné de manière décisive. Utilisez plutôt imagemin
Maison interface Web js tutoriel Comment compresser des images avec Node.js ? Présentation de la méthode

Comment compresser des images avec Node.js ? Présentation de la méthode

Jul 23, 2021 am 09:50 AM
node.js 压缩图片

Comment compresser des images à l'aide de Node.js ? L'article suivant vous expliquera comment utiliser Node.js pour réaliser une compression d'image.

Comment compresser des images avec Node.js ? Présentation de la méthode

1. Introduction au contenu

Il y a quelque temps, j'ai développé un plug-in Vscode pour télécharger des images sur Qiniu À cette époque, il manquait encore une fonction : cette fois, c'était la compression d'image. enfin résolu ; en même temps, un bug hérité (l'éditeur restera bloqué s'il y a des espaces dans le lien), il peut désormais être considéré comme un plug-in entièrement fonctionnel. Les amis intéressés peuvent rechercher le plug-in dans Vscode. pour l'installer. upload-to-qiniu

[Apprentissage recommandé : "

Tutoriel Nodejs"]

Aperçu de l'effet :

Comment compresser des images avec Node.js ? Présentation de la méthode

2. Au début, j'avais prévu d'utiliser l'API de pour réaliser la compression d'image. , mais après l'avoir essayé, j'ai découvert que la vitesse de compression était extrêmement lente et semblait coûter de l'argent, alors j'ai abandonné de manière décisive. Utilisez plutôt imagemin

.

TinyPNGIl y a un piège ici : puisque ne peut pas compresser directement les images, mais doit s'appuyer sur et

, mais elle ne sera pas installée lors de l'installation

, j'ai trouvé une raison pour laquelle cette bibliothèque est basée sur certains langages sous-jacents, donc elle. ne peut pas être installé directement et une autre dépendance doit être installée sur l'ordinateurimagemin. imagemin-jpegtranimagemin-pngquantimagemin-pngquantInstallez libpnglibpng

Publiez directement l'adresse pour installer Brew : zhuanlan.zhihu.com/p/90508170 Tapez simplement la commande qu'il dit et vous pouvez essentiellement installer Brew. Enfin, nous exécutons à nouveau

, attendons que

soit installé avec succès, puis installons dans le projet et il peut être installé. brew install libpnglibpngCode pour compresser les imagesimagemin-pngquantSelon les exigences, nous ne voulons certainement pas qu'il compresse les images et les mette dans le dossier, nous devons plutôt obtenir directement le contenu compressé dans le code et le télécharger directement sur Qiniu. . Ensuite, nous devons utiliser

. Cette méthode reçoit un objet

et renvoie un après compression. Il suffit d'utiliser le tampon compressé pour le télécharger directement sur Qiniu. Voici l'implémentation du code :

// 获取buffer
export const getBufferFromFile = (filePath: string): Promise<Buffer> => {
  return new Promise((resolve, reject) => {
    fs.readFile(filePath, function (err: any, res: any) {
      if (!err) {
        resolve(res)
      }
    })
  })
}


// 压缩图片,传入图片文件路径,通过getBufferFromFile方法转为buffer 后进行压缩
const imageGzip = async (loaclFile: string): Promise<any> => {
  const bufferFile = await getBufferFromFile(loaclFile)
  let res
  try {
    res = await imagemin.buffer(bufferFile, {
      plugins: [
        imageminJpegtran(),
        imageminPngquant({
          quality: [0.6, 0.8],
        }),
      ],
    })
  } catch (err) {
    console.log(&#39;error&#39;, err)
    res = null
  }
  return res
}
Copier après la connexion
imagemin.buffer In. de cette façon, nous pouvons facilement réaliser la compression d'image, maintenant nous la réécrivons et la téléchargeons sur Qiniu : Comme il n'y avait pas de compression auparavant, nous pouvons directement télécharger le chemin du fichier vers Qiniu. Après la compression, nous n'avons que le tampon, et nous. besoin de télécharger le tampon sur Qiniu : bufferbuffer

gzipImage ? 'putStream' : 'putFile', si nous obtenons le tampon, utilisez formUploader.putStream, sinon nous n'avons besoin que de formUploader.putFile pour télécharger

export const upImageToQiniu = async (
  loaclFile: string,
  cb: { (res: any): void; (arg0: any): void },
  upConfig: QiNiuUpConfig
) => {
  const config = new qiniu.conf.Config()
  const formUploader = new qiniu.form_up.FormUploader(config)
  const putExtra = new qiniu.form_up.PutExtra()
  const token = getToken(upConfig.accessKey, upConfig.secretKey, upConfig.scope)
  let gzipImage
  if (upConfig.gzip) {
    gzipImage = await imageGzip(loaclFile)
  }
  // 获取当前时间戳
  var key = new Date().getTime()
  // 上传调用方法
  const uploadFnName = gzipImage ? &#39;putStream&#39; : &#39;putFile&#39;
  // 上传内容
  const uploadItem = gzipImage ? bufferToStream(gzipImage) : loaclFile
  // 七牛上传
  formUploader[uploadFnName](
    token,
    key,
    uploadItem,
    putExtra,
    function (respErr: any, respBody: any, respInfo: any) {
      if (respErr) {
        throw respErr
      }

      if (respInfo.statusCode === 200) {
        const url = upConfig.domain + &#39;/&#39; + respBody.key
        cb(url)
      }
    }
  )
}
Copier après la connexion

Maintenant, nous pouvons expérimenter avec l'effet : Sélectionnez un png sur l'ordinateur Image :

Après l'avoir téléchargé avec notre plug-in, ouvrez le lien et jetez un œil :

Comment compresser des images avec Node.js ? Présentation de la méthode

L'image est compressée avec succès~~

Comment compresser des images avec Node.js ? Présentation de la méthode

3. Résoudre les bugs restants

J'ai trouvé un problème lors de son utilisation. Parfois, l'éditeur restait soudainement bloqué. Plus tard, j'ai découvert que la raison était qu'il restait bloqué lorsqu'il y avait des espaces dans le lien. les autres contenus en survol ne répondraient pas. Il suffit donc de supprimer les espaces dans la chaîne de survol, puis d'exécuter la méthode suivante pour obtenir le lien :
// 当前行的文本内容
const currentLineText = document.lineAt(position).text.replace(/\s+/g, "")
Copier après la connexion
IV Fin

Parce que lors de la prévisualisation des images au survol, afin d'éviter que certaines images ne soient trop grandes et trop lentes. pour charger, les paramètres de recadrage de Qiniu ont été ajoutés, de sorte que d'autres types de liens d'image peuvent ne pas être prévisualisables, ce qui sera résolu plus tard ^ ^. J'ai téléchargé le code source du plug-in sur github

, tout le monde est invité à cliquer sur Démarrer ^ ^. Si vous avez de meilleures idées de plug-ins, vous pouvez également communiquer entre vous.

Pour plus de connaissances sur la programmation, veuillez visiter : Introduction à la programmation

 ! !

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment MeituXiuXiu compresse-t-il la taille de l'image ? Tutoriel Meituxiuxiu sur la modification de la taille des photos en Ko ! Comment MeituXiuXiu compresse-t-il la taille de l'image ? Tutoriel Meituxiuxiu sur la modification de la taille des photos en Ko ! Mar 15, 2024 pm 10:34 PM

1. Comment Meitu Xiuxiu compresse-t-il la taille de l'image ? Tutoriel Meituxiuxiu sur la modification de la taille des photos en Ko ! 1. Accédez à l'application Meitu Xiu Xiu et cliquez sur Embellissement de l'image. 2. Accédez à l'interface des projets récents et sélectionnez les images qui doivent être compressées. 3. Entrez dans l'interface d'image et cliquez sur l'option d'édition ci-dessous. 4. Accédez à l'interface d'édition et sélectionnez le format d'image. 5. Une fois la sélection réussie, cliquez sur la taille au milieu de l'image pour entrer. 6. Entrez dans l'interface de modification de la taille, ajustez la taille de l'image et cliquez sur Enregistrer une fois l'ajustement terminé. 7. Revenez à l'interface d'image, recherchez l'icône en forme de coche dans le coin inférieur droit et cliquez dessus. 8. Enfin, dans l'interface de l'image compressée, cliquez sur Enregistrer et l'image sera compressée.

Un article pour parler du contrôle de la mémoire dans Node Un article pour parler du contrôle de la mémoire dans Node Apr 26, 2023 pm 05:37 PM

Le service Node construit sur une base non bloquante et piloté par les événements présente l'avantage d'une faible consommation de mémoire et est très adapté à la gestion de requêtes réseau massives. Dans le contexte de demandes massives, les questions liées au « contrôle de la mémoire » doivent être prises en compte. 1. Le mécanisme de récupération de place du V8 et les limitations de mémoire Js sont contrôlés par la machine de récupération de place

Explication graphique détaillée de la mémoire et du GC du moteur Node V8 Explication graphique détaillée de la mémoire et du GC du moteur Node V8 Mar 29, 2023 pm 06:02 PM

Cet article vous donnera une compréhension approfondie de la mémoire et du garbage collector (GC) du moteur NodeJS V8. J'espère qu'il vous sera utile !

Parlons de la façon de choisir la meilleure image Docker Node.js ? Parlons de la façon de choisir la meilleure image Docker Node.js ? Dec 13, 2022 pm 08:00 PM

Le choix d'une image Docker pour Node peut sembler trivial, mais la taille et les vulnérabilités potentielles de l'image peuvent avoir un impact significatif sur votre processus CI/CD et votre sécurité. Alors, comment choisir la meilleure image Docker Node.js ?

Parlons en profondeur du module File dans Node Parlons en profondeur du module File dans Node Apr 24, 2023 pm 05:49 PM

Le module de fichiers est une encapsulation des opérations de fichiers sous-jacentes, telles que l'ajout de lecture/écriture/ouverture/fermeture/suppression de fichiers, etc. La plus grande caractéristique du module de fichiers est que toutes les méthodes fournissent deux versions de **synchrone** et ** asynchrone**, with Les méthodes avec le suffixe sync sont toutes des méthodes de synchronisation, et celles qui n'en ont pas sont toutes des méthodes hétérogènes.

Node.js 19 est officiellement sorti, parlons de ses 6 fonctionnalités majeures ! Node.js 19 est officiellement sorti, parlons de ses 6 fonctionnalités majeures ! Nov 16, 2022 pm 08:34 PM

Node 19 est officiellement publié. Cet article vous donnera une explication détaillée des 6 fonctionnalités majeures de Node.js 19. J'espère qu'il vous sera utile !

Parlons du mécanisme GC (garbage collection) dans Node.js Parlons du mécanisme GC (garbage collection) dans Node.js Nov 29, 2022 pm 08:44 PM

Comment Node.js fait-il le GC (garbage collection) ? L’article suivant vous guidera à travers cela.

Parlons de la boucle d'événements dans Node Parlons de la boucle d'événements dans Node Apr 11, 2023 pm 07:08 PM

La boucle d'événements est un élément fondamental de Node.js et permet une programmation asynchrone en garantissant que le thread principal n'est pas bloqué. Comprendre la boucle d'événements est crucial pour créer des applications efficaces. L'article suivant vous donnera une compréhension approfondie de la boucle d'événements dans Node. J'espère qu'il vous sera utile !

See all articles