Cara yang sangat mudah untuk menggunakan font khusus dalam email tanpa harus menggunakan perangkat lunak seni.
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 menggunakan OS-font dan pkg-up (misalnya Anda tidak perlu menulis Arial.ttf , Anda bisa menulis Arial ).glyf dan PostScript cff Outline).alt , title , dan style color dan font-size berdasarkan opsi yang disahkan. Inilah cara lama, lambat, dan berbelit -belit Anda akan melakukan ini:
? Anda tidak perlu melakukannya lagi! ? Begini Betapa Mudahnya:
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; " >Anda sekarang dapat menggunakan font apa pun di email Anda - tanpa harus menggunakan perangkat lunak seni seperti Photoshop atau Sketch!
Ini mendukung font di seluruh sistem dan node_modules di luar kotak, tetapi Anda dapat melewati jalur file jika Anda ingin menggunakan font non-standar khusus. Anda juga dapat menyesuaikan kering, jangkar, warna/isi, stroke, ukuran font (bahkan dalam titik jika diperlukan), tambahkan atribut khusus ke tag HTML, dan banyak lagi! Lihat Penggunaan, Opsi, dan Referensi API di bawah ini untuk info lebih lanjut.
Bahkan menggunakan algoritma levenshtein cepat untuk mendeteksi kecocokan terdekat dengan ejaan font (misalnya jika Anda salah mengartikan Arial sebagai Arail ).
Menggunakan opsi yang ditentukan dalam pendekatan baru di atas, kode berikut memberikan contoh metode API paket ini.
| Metode dan pratinjau API | Tipe gambar |
|---|---|
customFonts.svg(options) | SVG Tag <svg> |
customFonts.img(options) | Tag IMG <img> dengan SVG inline yang dikodekan Base64 |
customFonts.png(options, scale) | Tag IMG <img> dengan PNG inline yang dikodekan Base64 |
customFonts.png@2x(options) | Tag IMG <img> dengan resolusi inline png @2x base64 |
customFonts.png@3x(options) | Tag IMG <img> dengan resolusi inline png @3x base64 |
Terakhir, inilah gambar yang rusak seperti itu yang berusaha diterjemahkan dengan metode API. Itu memanfaatkan opsi supportsFallback yang ditentukan di bawah ini dalam opsi. Ini adalah fallback yang sangat berguna untuk email offline, gambar cache tidak valid, dan banyak lagi!
npm install -s custom-fonts-in-emails import customFonts from 'custom-fonts-in-emails' ;atau
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' ;Jika Anda berencana untuk menggunakan ini untuk email keluar, maka Anda ingin menggunakan nodemailer dan nodemailer-base64-to-S3. Atau Anda bisa menggunakan LAD, yang sudah memiliki bawaan ini!
Argumen options dalam semua metode API adalah objek yang menerima properti berikut:
| Milik | Jenis | Keterangan |
|---|---|---|
text | Rangkaian | Teks untuk menulis menggunakan keluarga font yang ditentukan di fontNameOrPath (default ke string kosong '' ) |
fontNameOrPath | Rangkaian | Nama atau jalur file font (default ke Arial -perhatikan bahwa secara default kami memuat pengguna pengguna, lokal, jaringan, sistem, dan node_modules di seluruh sistem operasi menggunakan font OS, sehingga Anda dapat menggunakan font yang diinstal!) |
fontSize | Nomor atau string | Ukuran font dalam piksel , yang dibulatkan ke seluruh bilangan bulat terdekat (ini secara otomatis menetapkan options.textToSvg.fontSize - default ke 24px , tetapi Anda tidak perlu menentukan imbuhan px karena secara otomatis dilucuti dan dikonversi ke seluruh integer terdekat menggunakan Math.round(parseInt(val, 10)) - ini harus lebih besar dari MATH. |
fontColor | Rangkaian | Warna hex valid atau nilai RGBA untuk membuat warna pengisian teks dengan (default ke #000 ) |
backgroundColor | Rangkaian | Warna hex valid atau nilai RGBA untuk membuat warna latar belakang dengan (default ke transparent ) |
supportsFallback | Boolean | Pastikan bahwa gambar output memiliki title atribut fallback dan alt ( options.fontSize / 2 diatur ke nilai options.text px , dan style font-size diatur ke atau line-height dengan color text-align: center diatur ke options.fontColor options.fontSize customFonts.svg (default ke true ) |
resizeToFontSize | Boolean | Pastikan bahwa tinggi gambar output diubah ukurannya menjadi fontSize , dan lebarnya diskalakan secara proporsional - tidak berlaku untuk customFonts.svg atau customFonts.img (default ke false ) |
trim | Boolean | Pastikan bahwa gambar output dipangkas menggunakan metode API trim Sharp - itu trims "boring" piksel dari tepi - tidak berlaku untuk customFonts.svg atau customFonts.img (default ke false ) |
trimTolerance | Nomor | Harus dari 1-99 inklusif, menetapkan nilai toleransi trim menggunakan trim (default ke 10 ) |
attrs | Obyek | Attribute key-value pairs that will be applied to the returned tag (defaults to {} , eg if you want to make the image output a fixed height scaled proportionally, then you can do { style: 'height: 40px; width: auto;' } , this is useful if you want to add custom CSS classes, style attributes, or other attributes in general to the returned tags ) |
textToSvg | Obyek | Opsi yang ditentukan dalam TextToSVG di bawah ini yang diteruskan ke Text-to-SVG (dan selanjutnya opentype.js): |
| Milik | Jenis | Keterangan |
|---|---|---|
x | Nomor | Posisi horizontal awal teks (default ke 0 ) |
y | Nomor | Posisi vertikal dari baseline teks (default ke 0 ) |
fontSize | Nomor | Ukuran teks dalam poin (default ke options.fontSize ) |
anchor | Rangkaian | Jangkar objek dalam koordinat (default ke left top - string terdiri dari horizontal vertical , di mana horizontal dapat menjadi salah satu dari left , center , atau right , dan vertical dapat menjadi salah satu baseline , top , middle , bottom ) |
attributes | Obyek | Atribut Pasangan nilai kunci yang akan diterapkan pada elemen <path> yang dikembalikan di dalam tag <svg> (default ke { fill: '#000', stroke: 'none' } -perhatikan bahwa jika Anda menentukan fontColor maka itu akan diisi fill sama dengan fontColor , tetapi dapat ditimpa atribut ini secara eksplisit!) |
customFonts.setDefaults(options)Fungsi yang menerima opsi untuk mengatur default untuk penggunaan di masa mendatang dan mengembalikan janji yang diselesaikan dengan paket baru default.
customFonts.setOptions(options) Fungsi yang menerima opsi dan mengembalikan janji yang diselesaikan dengan options yang disempurnakan.
customFonts.svg(options) Fungsi yang menerima opsi dan mengembalikan janji yang diselesaikan dengan serangkaian tag HTML <svg> untuk font khusus.
Fungsi ini mengambil options argumen dan meneruskannya ke customFonts.setOptions .
customFonts.img(options) Sama seperti customFonts.svg , kecuali mengembalikan string sebagai data inlined base64.
customFonts.png(options, scale) Sama seperti customFonts.img , kecuali mengembalikan data inline base64 untuk PNG alih -alih SVG.
Ini juga secara opsional menerima scale angka (default ke 1 ), yang akan skala gambar untuk dukungan retina.
Misalnya, jika font yang diberikan adalah 20px, maka akan mengalikan 20px dengan scale (misalnya skala jika scale 2 , maka gambar yang dikembalikan akan 20px tetapi akan diskalakan ke 40px ).
customFonts.png2x(options) Sama seperti customFonts.png , kecuali mengembalikan gambar dengan dua kali lebih banyak piksel (dikalikan fontSize * 2 dan mengembalikan gambar yang ditingkatkan menjadi 1x untuk dukungan retina 2x, lulus 2 sebagai scale ).
customFonts.png3x(options) Sama seperti customFonts.png , kecuali mengembalikan gambar dengan tiga piksel sebanyak (itu melipatgandakan fontSize * 3 dan mengembalikan gambar yang ditingkatkan menjadi 1x untuk dukungan retina 3x, lulus 3 sebagai scale ).
customFonts.getAvailableFontPaths() Fungsi yang mengembalikan array jalur file untuk semua font pengguna, lokal, jaringan, sistem, dan node_modules yang tersedia pada sistem operasi saat ini.
customFonts.getAvailableFontNames() Sama seperti customFonts.getAvailableFontPaths , kecuali mengembalikan nama font, bukan jalur font.
customFonts.customFontsCacheIni adalah objek dari semua font khusus di -cache.
MIT © Nick Baugh