Skip to content

RadLikeWhoa/Countable

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

56 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Countable

Countable is a JavaScript function to add live paragraph-, word- and character-counting to an HTML element. Countable is a zero-dependency library and comes in at 1KB when minified and gzipped.

View the Demo

Installation

The preferred method of installation is bower: bower install Countable. Alternatively, you can download the latest zipball or copy the script directly.

Usage

Countable is available as a Node / CommonJS module, an AMD module and as a global. All methods are accessed on the Countable object directly.

Callbacks

The live and once method both accept a callback. The given callback is then called whenever needed with a single parameter that carries all the releavant data. this is bound to the current element. Take the following code for an example.

var area = document.getElementById('text')

Countable.once(area, function (counter) {
  console.log(this, counter)
})
=> <textarea id="text"></textarea>, { all: 0, characters: 0, paragraphs: 0, words: 0 }
Property Meaning
paragraphs The number of paragraphs. Paragraphs can be separated by either a soft or a hard (two line breaks) return. To use hard returns, set the corresponding option (hardReturns).
words The number of words. Words are split using spaces.
characters The number of characters (without spaces). This contains all non-whitespace characters.
all The number of characters including whitespace. This is the total number of all characters in the element.

Countable#live(elements, callback, options)

Bind the callback to all given elements. The callback gets called everytime the element's value or text is changed.

Countable.live(area, function (counter) {
  console.log(counter)
})

Countable#die(elements)

Remove the bound callback from all given elements.

Countable.die(area)

Countable#once(elements, callback, options)

Similar to Countable.live(), but the callback is only executed once, there are no events bound.

Countable.once(area, function (counter) {
  console.log(counter)
})

Countable#enabled(element)

Checks the live-counting functionality is bound to the given.

Countable.enabled(area)

Options

Countable.live() and Countable.once() both accept a third argument, an options object that allows you to change how Countable treats certain aspects of your element's text.

{
  hardReturns: false,
  stripTags: false
}

By default, paragraphs are split by a single return (a soft return). By setting hardReturns to true, Countable splits paragraphs after two returns.

Depending on your application and audience, you might need to strip HTML tags from the text before counting it. You can do this by setting stripTags to true.

Browser Support

Countable supports all modern browsers. Internet Explorer is supported down to version 7. Note that some browsers don't implement the oninput event consistently so there might be differences in the way Countable works in different browsers.

About the Author

My name is Sacha Schmid (@sachaschmid). I'm a front-end engineer from Switzerland. I am the creator of SSGS and other open source projects.

Are you using Countable in a project? I'd love to see what you've achieved. Just send me a tweet.

Contributors