Type.js adds new type properties to your CSS, giving you the control you need for type on the web. You can write these properties in your CSS and they will work like any other property.
View index.html
to see these new properties in action.
Adjust the space between specific glyphs with a clear syntax. Just type in the two glyphs you want to kern, then the amount space you want.
kerning-pairs
accepts a comma separated list of two glyphs, then the distance you want between them. Accepts positive or negative distances.
kerning-pairs: az 0.02em;
Values: {Any glyph}{Any glyph} {Any distance}{Any CSS unit}
h1 {
font-size: 3em;
line-height: 1.2;
kerning-pairs: az 0.02em,
zy 0.01em,
th 0.01em,
ov -0.02em;
}
Set rules for where you want your lines to break in a paragraph.
rag-adjust
accepts four values that describe where your lines should break.
rag-adjust: small-words;
Values:
emphasis
– Text of three or less words in bold or italics does not break across lines.small-words
– Breaks lines before words of three or less characters.prepositions
– Breaks lines before prepositions.dashes
– Breaks lines before hyphens and dashes.all
– Breaks lines before all of the above.
p, li, h3, dd {
max-width: 35em;
rag-adjust: small-words;
}
Set rules for how you want to adjust styles to eliminate widows – or any grouping of less than 14 characters on the last line of a paragraph – in your text.
widow-adjust
accepts the style property you want to use to fix your paragraph.
widow-adjust: padding-right;
Values:
padding-right
– Increasespadding-right
until the widow is fixed. (Usingbox-sizing: border-box;
)padding-left
– Increasespadding-left
until the widow is fixed. (Usingbox-sizing: border-box;
)word-spacing
– Removesword-spacing
until the widow is fixed.nbsp
– Adds a
character between the last few words of the paragraph.
p, li, h3, dd {
max-width: 35em;
widow-adjust: padding-right;
}
Set a minimum and maximum font-size for text when using a viewport unit for font-size.
min-font-size
and max-font-size
accepts any font-size
value and CSS unit. Does not accept viewport units.
min-font-size: 20px;
Values: {Any value}{Any css unit}
h1 {
font-size: 3em;
font-size: 4vw;
max-font-size: 50px;
min-font-size: 30px;
}
Type.js only works within style
tags on a page. For now. You can try using your external stylesheets by changing an option in the type.js
file. Change:
stylefill.options({
externalCSS : false
});
To:
stylefill.options({
externalCSS : true
});
Note: This will cause the browser to download your external CSS files twice. Once, as per usual, and again to read the type.js
property values.