Skip to content

mistakster/pretty-header

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

37 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Pretty Header

Split a text into lines with almost equal width.

Demo

Have a look at the demo page to see this script in action.

Original and processed versions side by side

Usage

As npm package

$ 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');
}

As a script

<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>

As jQuery plugin

<script src="jquery-2.1.4.js"></script>
<script src="pretty-header.js"></script>
<script>
  $(function () {
    $('.pretty').prettyHeader('nowrap');
  });
</script>

API

prettyHeader(element, option)

element

Type: Node

Container element.

option

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.

License

MIT © Vladimir Kuznetsov

About

Split a text into lines with almost equal width.

Resources

License

Stars

Watchers

Forks

Packages

No packages published