Split a text into lines with almost equal width.
Have a look at the demo page to see this script in action.
$ npm install pretty-header
var prettyHeader = require('pretty-header');
var i, elements;
elements = document.querySelectorAll('.pretty');
for (i = 0; i < elements.length; i++) {
prettyHeader(elements[i], 'nowrap');
}
<script src="pretty-header.js"></script>
<script>
var i, elements;
elements = document.querySelectorAll('.pretty');
for (i = 0; i < elements.length; i++) {
prettyHeader(elements[i], 'nowrap');
}
</script>
<script src="jquery-2.1.4.js"></script>
<script src="pretty-header.js"></script>
<script>
$(function () {
$('.pretty').prettyHeader('nowrap');
});
</script>
Type: Node
Container element.
Type: String|Function
Each line of text will be wrapper into the element with
applied white-space: nowrap
style. You can provide class name
or factory function for such elements.
If option is a string, it will be using as class for <span>
.
If option is a function, it should return new DOM-Node.
prettyHeader(element, function () {
var helper = document.createElement('div');
helper.className = 'pretty-header-helper';
return helper;
});
This trick may help to get neutral inline-styled element when ordinary
<span>
has inappropriate CSS.
MIT © Vladimir Kuznetsov