Eine äußerst einfache Möglichkeit, benutzerdefinierte Schriftarten in E -Mails zu verwenden, ohne Kunstsoftware verwenden zu müssen.
customFonts.setDefaults(options)customFonts.setOptions(options)customFonts.svg(options)customFonts.img(options)customFonts.png(options, scale)customFonts.png2x(options)customFonts.png3x(options)customFonts.getAvailableFontPaths()customFonts.getAvailableFontNames()customFonts.customFontsCachenode_modules -Ordner-Schriftarten mit OS-FONT und PKG-up (z. B. müssen Sie nicht Arial.ttf schreiben, Sie können nur Arial schreiben).glyf und PostScript cff -Umrissen).alt , title und style von color und font-size basierend auf den übergebenen Optionen. Hier ist die alte, langsame und verworrene Art, wie Sie das tun würden:
? Das musst du nicht mehr tun! ? So einfach ist es:
import customFonts from 'custom-fonts-in-emails' ;
import path from 'path' ;
const options = {
text : 'Make something people want' ,
fontNameOrPath : 'GoudyBookletter1911' ,
fontColor : 'white' ,
backgroundColor : '#ff6600' ,
fontSize : 40
} ;
customFonts . png2x ( options )
. then ( console . log )
. catch ( console . error ) ; < img width =" 461 " height =" 51 " src ="  " title =" Make something people want " alt =" Make something people want " style =" color: white;font-size: 25.5px;line-height: 51px;text-align: center;background-color: #ff6600; " >Sie können jetzt jede Schriftart in Ihren E -Mails verwenden - ohne Kunstsoftware wie Photoshop oder Sketch verwenden zu müssen!
Es unterstützt systemweite und node_modules -Schriftarten außerhalb der Box. Sie können jedoch einen Dateipfad übergeben, wenn Sie eine benutzerdefinierte nicht standardmäßige Schriftart verwenden möchten. Sie können auch Kerning, Anker, Farbe/Füllung, Schlaganfall, Schriftgröße (sogar in Punkten bei Bedarf) anpassen, dem HTML -Tag benutzerdefinierte Attribute hinzufügen, und vieles mehr! Weitere Informationen finden Sie unter Verwendung, Optionen und die API -Referenz unten.
Es verwendet sogar den Fast-Levenshtein-Algorithmus, um die engste Übereinstimmung mit der Schreibweise einer Schriftart zu erkennen (z. B. für den Fall, dass Sie Arial als Arail falsch beschrieben haben).
Mit den Optionen, die im obigen neuen Ansatz definiert sind, enthält der folgende Code Beispiele für die API -Methoden dieses Pakets.
| API -Methode und Vorschau | Bildtyp |
|---|---|
customFonts.svg(options) | SVG -Tag <svg> |
customFonts.img(options) | IMG-Tag <img> mit Base64-codiert inline SVG |
customFonts.png(options, scale) | IMG-Tag <img> mit Base64-codiert inline PNG |
customFonts.png@2x(options) | IMG-Tag <img> mit Base64-codiert inline PNG @2x Auflösung |
customFonts.png@3x(options) | IMG-Tag <img> mit Base64-codiert inline PNG @3x Auflösung |
Zuletzt ist hier ein kaputtes Bild aussieht, als er versucht hat, mit einer API -Methode gerendert zu werden. Sie verwenden die unten in Optionen definierte supportsFallback . Dies ist ein wirklich nützlicher Fallback für Offline -E -Mails, ungültige zwischengespeicherte Bilder und vieles mehr!
npm install -s custom-fonts-in-emails import customFonts from 'custom-fonts-in-emails' ;oder
import {
setDefaults ,
setOptions ,
svg ,
img ,
png ,
png2x ,
png3x ,
getClosestFontName ,
getFontPathsByName ,
getFontPathByName ,
getAvailableFontPaths ,
getAvailableFontNames ,
// optional: this is a cache of all the custom fonts loaded
customFontsCache
} from 'custom-fonts-in-emails' ;Wenn Sie dies für ausgehende E-Mails verwenden möchten, möchten Sie NodeMailer und Nodemailer-Base64-to-S3 verwenden. Oder Sie können einfach LAD verwenden, der dieses integrierte bereits eingebaut hat!
Das options in allen API -Methoden ist ein Objekt, das die folgenden Eigenschaften akzeptiert:
| Eigentum | Typ | Beschreibung |
|---|---|---|
text | Saite | Text zum Schreiben mit der in fontNameOrPath angegebenen Schriftfamilie (Standardeinstellung zu einer leeren Zeichenfolge von '' ) |
fontNameOrPath | Saite | Name oder Dateipfad der Schriftart (Standardeinstellungen zu Arial -Beachten Sie, dass wir standardmäßig Benutzer-, Lokal-, Netzwerk-, System- und node_modules -Schriftarten über ein beliebiges Betriebssystem über OS-FONTs laden, sodass Sie eine installierte Schriftart verwenden können!) |
fontSize | Nummer oder Zeichenfolge | Größe der Schriftart in Pixeln , die auf die gesamte ganze Ganzzahl gerundet ist (dies setzt automatisch options.textToSvg.fontSize - Standards bis 24px , aber Sie müssen den Affix px nicht angeben, da es automatisch gestreift und auf die nächste Ganzzahl mit Math.round(parseInt(val, 10)) . |
fontColor | Saite | Gültige Hex -Farbe oder RGBA -Wert, um die Textfüllfarbe mit (Standardeinstellung auf #000 ) zu rendern |
backgroundColor | Saite | Gültige Hex -Farbe oder RGBA -Wert, um die Hintergrundfarbe mit (Standardeinstellung zu transparent ) zu rendern |
supportsFallback | Boolean | Stellen Sie sicher, dass das Ausgangsbild einen Fallback- title und alt enthält ( options.fontSize / 2 auf px font-size der options.text festgelegt.Text) und style , line-height auf options.fontColor eingestellt ist oder mit color eingestellt text-align: center options.fontSize customFonts.svg (Standardeinstellungen zu true ) |
resizeToFontSize | Boolean | Stellen Sie sicher, dass die Ausgangsbildhöhe in fontSize geändert wird und die Breite proportional skaliert ist - weder für customFonts.svg noch customFonts.img (Standardeinstellungen auf false ) |
trim | Boolean | Stellen Sie sicher, dass das Ausgabebild mit der Sharp -Trim -API -Methode beschnitten wird - es wird von den Kanten "Bohrung" -Pixel "gepackt" - nicht für customFonts.svg oder customFonts.img (Standardeinstellung zu false ) anwendbar) |
trimTolerance | Nummer | Muss von 1-99 inklusive sein, legt den Trim-Toleranzwert mithilfe von TRIM (Standardeinstellungen auf 10 ) fest. |
attrs | Objekt | Attributschlüsselwertepaare, die auf das zurückgegebene Tag angewendet werden (Standardeinstellungen zu {} { style: 'height: 40px; width: auto;' } z. B. wenn Sie das Bild ausgeben möchten, können Sie proportional skaliert werden. |
textToSvg | Objekt | Optionen, die in textTOSVG definiert sind, wobei sie an Text-to-SVG (und anschließend Openentype.js) übergeben werden: |
| Eigentum | Typ | Beschreibung |
|---|---|---|
x | Nummer | Horizontale Position des Beginns des Textes (standardmäßig auf 0 ) |
y | Nummer | Vertikale Position der Basislinie des Textes (Standardeinstellung auf 0 ) |
fontSize | Nummer | Größe des Textes in Punkten (Standardeinstellungen zu options.fontSize ) |
anchor | Saite | Anker des Objekts in middle Koordinate bottom Standardeinstellungen nach left top - Die Saite besteht aus horizontal vertical , bei top horizontal left , center oder right und vertical sein kann baseline |
attributes | Objekt | Attributschlüsselwertepaare, die im Return <path> -Element im <svg> -Tag angewendet werden (Standardeinstellungen zu { fill: '#000', stroke: 'none' } -Beachten Sie, dass wenn Sie fontColor angeben, füllen Sie fill gleichzeitig mit dem fontColor . |
customFonts.setDefaults(options)Eine Funktion, die Optionen akzeptiert, um Standardeinstellungen für die zukünftige Nutzung festzulegen, und ein Versprechen zurückgibt, das mit den neuen Paket -Standardeinstellungen aufschließt.
customFonts.setOptions(options) Eine Funktion, die Optionen akzeptiert und ein Versprechen zurückgibt, das mit raffinierten options auflöst.
customFonts.svg(options) Eine Funktion, die Optionen akzeptiert und ein Versprechen zurückgibt, das mit einer Zeichenfolge des <svg> html -Tags für die benutzerdefinierte Schriftart auflöst.
Diese Funktion übernimmt die options und übergibt sie an customFonts.setOptions .
customFonts.img(options) Wie customFonts.svg , außer dass sie die Zeichenfolge als Base64 -Inline -Daten zurückgibt.
customFonts.png(options, scale) Gleich wie customFonts.img , außer dass es Base64 -Inline -Daten für ein PNG anstelle eines SVG zurückgibt.
Es akzeptiert optional auch eine scale (Standardeinstellungen bis 1 ), die das Bild für die Unterstützung von Retina skaliert.
Wenn beispielsweise die umgeführte Schriftart 20px beträgt, multiplizieren Sie 20px für scale (z. B. wenn scale 2 ist, dann wird das zurückgegebene Bild 20px sein, aber es wird auf 40px skaliert).
customFonts.png2x(options) Gleich wie customFonts.png , außer es gibt ein Bild mit doppelt so viele Pixel zurück (es multipliziert fontSize * 2 und gibt ein Bild zurück 2 das für 2x Retina -Unterstützung scale ist.
customFonts.png3x(options) Gleich wie customFonts.png , außer es gibt ein Bild mit drei Pixeln zurück (es multipliziert fontSize * 3 und gibt ein Bild zurück, das für die 3 -fache -Retina -Unterstützung auf 3 scale ist.
customFonts.getAvailableFontPaths() Eine Funktion, die eine Reihe von Dateipfaden für alle Benutzer-, Lokal-, Netzwerk-, System- und node_modules -Schriftarten, die im aktuellen Betriebssystem verfügbar sind, zurückgeben.
customFonts.getAvailableFontNames() Das Gleiche wie customFonts.getAvailableFontPaths Font -Namen anstelle von Schriftartpfade zurückgibt.
customFonts.customFontsCacheDies ist ein Objekt aller benutzerdefinierten Schriftarten.
Mit © Nick Baugh